我们即将进行眼动追踪研究,我们将尝试评估屏幕上显示的特定单词的注视。 我有很多.txt文件需要转换为图像并显示在屏幕上进行实验。 我正在尝试找到一种布局文本的方法,以便我知道屏幕上每个单词的确切位置和长度。
我想过使用tkinter来布局画布中的文本。 我不太确定这是一个好方法以及如何将输出转换为图像。 另一种方法是使用PIL。
有什么建议吗?
谢谢!!!
答案 0 :(得分:1)
如果您使用带有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()