我有一些像这样的代码
from Tkinter import *
master = Tk()
def oval_mouse_click(event):
print "in oval"
def canvas_mouse_click(event):
print "in canvas"
w = Canvas(master, width = 800, height = 600)
uid = w.create_oval(390, 290, 410, 310, fill='blue')
w.tag_bind(uid, "<Button-1>", lambda x: oval_mouse_click(x))
w.bind("<Button-1>" , canvas_mouse_click)
w.pack()
mainloop()
当我点击Canvas时,我在画布上有#34;&#34;控制台中的消息。 当我点击椭圆形时,我有两条消息&#34;在椭圆形&#34;和&#34;在画布&#34;,但我想只有第一条消息。有没有办法阻止事件的发生?
我可以用一些全局标志来完成这项任务,但我认为Tkl应该有更自然的方式。
答案 0 :(得分:2)
以下是处理问题的最简单示例:
import Tkinter
def oval_mouse_click(event):
print "in oval"
event.widget.tag_click = True
def canvas_mouse_click(event):
if event.widget.tag_click:
event.widget.tag_click = False
return
print "in canvas"
root = Tkinter.Tk()
canvas = Tkinter.Canvas(width=400, height=300)
oid = canvas.create_oval(400/2-10, 300/2-10, 400/2+10, 300/2+10, fill='blue')
canvas.tag_click = False
canvas.tag_bind(oid, "<Button-1>", oval_mouse_click)
canvas.bind("<Button-1>" , canvas_mouse_click)
canvas.pack()
root.mainloop()
在Canvas
下,没有其他更简单的方法可以解决此问题。
答案 1 :(得分:0)
我刚刚在Python tkinter: stopping event propagation in text widgets tags处发布了类似问题的改进解决方案。
核心思想与之前的解决方案中提出的相同:通过将Canvas
小部件与tag_bind
相同的事件序列绑定来劫持return "break"
小部件。我提出的改进的解决方案现在可以模拟Tk的其他绑定+回调对的预期callback
行为。简而言之:
callback
创建一个包装器,即一个可调用的类实例"break"
并检查其结果。
bind
,则暂时劫持事件传播:Canvas
tag_bind
窗口小部件到绑定到unbind
的同一事件,并返回空回调。然后,在空闲时间"break"
。Canvas
:什么也不做,事件将自动传播到Text
上面的链接列出了{{1}}窗口小部件的完整工作示例,但它可以立即转移到Canvas窗口小部件。