我们即将进行一项眼球追踪研究,尝试评估对屏幕上显示的特定单词的注视。 我有很多 .txt 文件需要转换为图像并显示在屏幕上进行实验。 我正在尝试找到一种方法来布局文本,以便我知道屏幕上每个单词的确切位置和长度。
我想到使用 tkinter 在 Canvas 内布局文本。 我不太确定这是否是一个好方法以及如何将输出转换为图像。 另一种选择可能是使用 PIL。
有什么建议吗?
谢谢!!!
最佳答案
如果您使用 Canvas ,则 bbox
您可以返回项目的边界框。
from Tkinter import *
def callback(event, text_id):
print event.widget.bbox(text_id)
root = Tk()
canvas = Canvas(root, width=400, height=200)
text = "the lazy dog jumped over the brown fox"
offset = 20
for word in text.split(" "):
text_id = canvas.create_text(offset, 50, text=word, anchor=W)
bbox = canvas.bbox(text_id)
offset += bbox[2] - bbox[0] + 5
canvas.tag_bind(text_id, "<Button-1>",
lambda e, i=text_id: callback(e, i))
canvas.pack()
root.mainloop()
关于text - 获取TKINTER中屏幕上显示的文本的位置/坐标和大小,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16654648/