我想绑定(bind)到框架的入口/导出。这很简单,但似乎当我将鼠标悬停在框架中的某个小部件上时,它会被困为框架的导出(我想是因为框架在小部件的区域中不“可见”。您可以看到这个通过运行以下代码来实现效果,这意味着显示一个文本字段(标签),然后在输入框架时更改为可编辑字段。一旦按钮位于文本区域本身,它就会返回到标签。我是很难想出解决这个问题的方法。(我需要捕获框架的入口,而不仅仅是文本区域。这只是一个玩具示例)
from tkinter import *
class MainWindow(Frame):
def __init__(self,master):
super().__init__(master)
self.master = master
#self.master.state('zoomed')
self.pack()
self.edit = 0
self.initUI()
def initUI(self):
self.c = Canvas(self, height = 100, width = 400, bg = "red")
self.c.pack()
self.bind('<Enter>', lambda *args: textarea.display(1))
self.bind('<Leave>', lambda *args: textarea.display(0))
self.textstring = StringVar()
self.textstring.set("Hello")
textarea = TextArea(self.c,self.edit,self.textstring)
textarea.display(2)
self.c.create_window(10,10,window = textarea,anchor = NW)
class TextArea(Frame):
def __init__(self,master,active,textstr):
super().__init__()
self.master = master
self.active = active
self.textstr = textstr
self.inflag = False
def display(self,e):
if e == 0:
for child in self.winfo_children():
child.destroy()
L = Label(self,text = self.textstr.get(),relief = "flat")
L.pack()
elif e ==1:
for child in self.winfo_children():
child.destroy()
E = Entry(self,textvariable = self.textstr,width = 10)
E.pack()
elif e == 2:
L = Label(self, text=self.textstr.get(), relief="flat")
L.pack()
root = Tk()
mainframe = MainWindow(root)
mainframe.pack()
root.mainloop()
最佳答案
这里的实际问题相当微妙:在 TextArea
中的__init__
,您未能传递master
父类(super class)的参数,因此它默认为根窗口的子窗口。换句话说,TextArea 实际上是 MainWindow 的同级,而不是您想要的后代。因此,有必要有一个<Leave>
从一到<Enter>
另一个。解决办法是super().__init__(master)
,就像您在 MainWindow
中所做的那样.
关于python - tkinter中的Trapping Frame入口,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43927665/