gpt4 book ai didi

python - 我可以在文本小部件内创建跨多行的 Tkinter Canvas 吗?

转载 作者:行者123 更新时间:2023-12-01 00:19:54 25 4
gpt4 key购买 nike

我想创建一个文本小部件,其中可以将 Canvas 插入到文本中。我几乎已经完美了,但是我需要 Canvas 占据两行空间。我希望第一行“Tom 24/11/2019”与 Canvas 顶部对齐,第二行“Hi Jim”与 Canvas 底部对齐。我想做的事情有可能实现吗?

import tkinter as tk

sender='Tom'
dt='24/11/2019'
message='Hi Jim!'

root = tk.Tk()

text = tk.Text(root)
text.pack(padx = 10, pady = 10)

text.window_create(tk.END, window = tk.Canvas(root,bg='red',width=50,height=50)) # Example 2

text.tag_configure("sender", font="Arial 12 bold")
text.tag_configure("message", font="Arial 10",lmargin1=55,lmargin2=55)
text.tag_configure("date", font="Arial 8")

text.insert("end", sender.title()+' ',"sender")
text.insert("end", dt+'\n','date')
text.insert("end", message+'\n\n', 'message')


root.mainloop()

最佳答案

添加到文本的小部件window_create()有点像单个字符,您无法在其旁边的多行上添加文本。

这是一个解决方法(如果我明白你想要什么)。它创建一个 Frame 来保存图像和 Text 小部件,并将它们打包在一起。这使得文本独立于图像,您可以将字符串放入其中,它们将与左边缘对齐。

让第二个字符串在底部对齐也许是可能的,但我不知道有什么方法可以精确地做到这一点。在下面的代码中,我只是在两个字符串之间插入了一个空行,结果恰好很好(IMO)。

import tkinter as tk


sender = 'Tom'
dt = '24/11/2019'
message = 'Hi Jim!'

root = tk.Tk()

frame = tk.Frame(root, bg='white', bd=0, highlightthickness=0)
frame.pack()

canvas = tk.Canvas(frame, bg='red', width=50, height=50)
canvas.pack(side=tk.LEFT, anchor=tk.NW)
text = tk.Text(frame, bd=0)
text.pack(side=tk.LEFT, anchor=tk.NW)

text.tag_configure("sender", font="Arial 12 bold")
text.tag_configure("message", font="Arial 10") # , lmargin1=55, lmargin2=55)
text.tag_configure("date", font="Arial 8")

text.insert("end", sender.title()+' ', "sender")
text.insert("end", dt+'\n', 'date')
text.insert("end", '\n') # Add a blank line to move next one down.
text.insert("end", message+'\n\n', 'message')

root.mainloop()

截图

screenshot showing text lined up next to image

关于python - 我可以在文本小部件内创建跨多行的 Tkinter Canvas 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59022236/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com