我试图用tkinter制作一种GUI,下面是代码。但是,当我运行它时,单击设置,然后返回,python崩溃了。你知道为什么会发生这种情况吗?我该怎么解决它?当我运行destroy函数或在另一个Tk窗口中执行某个操作时
代码:(有些可能不需要,但我会包括它)
import tkinter as tk
class moveFrame():
def move(self, event):
widget = event.widget
widget.place(x = widget.winfo_x() + event.x - widget.startX, y = widget.winfo_y() + event.y - widget.startY)
def resize(self, event):
widget = event.widget
wlength = widget["length"]
wwidth = widget["width"]
widget.config(length = wlength + event.x - widget.startX, width = wwidth + event.y - widget.startY)
def getPos(self, event):
widget = event.widget
widget.lift()
widget.startX, widget.startY = event.x, event.y
def __init__(self, master, frameInfo, xPos, yPos):
self.frame = tk.Frame(master, cnf = frameInfo)
self.frame.bind("<Button-1>", self.getPos)
self.frame.bind("<B1-Motion>", self.move)
self.frame.bind("<B3-Motion>", self.getPos)
self.frame.bind("<Button-3>", self.resize)
self.frame.place(x = xPos, y = yPos)
def homescreen():
screen = tk.Tk()
#arrangeButton = tk.Canvas(screen, width = 120, height = 40, bg = "purple")
#arrangeButton.create_text(60, 20, text = "Arrange Homescreen")
#arrangeButton.place(x = 0, y = 0)
#arrangeButton.bind("<Button-1>", lambda event: arrange(arrangeButton))
settingsButton = tk.Canvas(screen, width = 60, height = 60)
settingsButton.place(x = 20, y = 20)
settingsButton.create_oval(5, 5, 58, 58, fill = "#a6a6a6", tags = "click")
settingsButton.create_oval(15, 10, 58, 53, fill = "#000", tags = "click")
settingsButton.create_oval(27, 22, 46, 41, fill = "#00f", tags = "click")
settingsButton.tag_bind("click", "<Button-1>", lambda event: settings())
def settings():
sscreen = tk.Tk()
#Get previous settings
try:
file = open("settings.txt", "r")
except IOError:
file = open("settings.txt", "x")
finally:
file = open("settings.txt", "r+")
curSet = [x.strip("\n") for x in file.readlines()]
#Widgets
back = tk.Canvas(sscreen, width = 60, height = 48)
back.place(x = 20, y = 20)
back.create_rectangle(25, 22, 60, 26, fill = "#000", tags = "sclick")
back.create_polygon(10, 24, 25, 10, 25, 38, fill = "#000", tags = "sclick")
back.create_text(42, 32, text = "Back", tags = "sclick")
back.tag_bind("sclick", "<Button-1>", lambda event: sscreen.destroy())
def arrange(*widgets):
arrangeScreen = tk.Tk()
arrangeButton = widgets[0]
aBaF = moveFrame(arrangeScreen, {"bd" : 4, "bg" : "#a6a6a6"}, arrangeButton.winfo_x() - 4, arrangeButton.winfo_y() - 4)
aBa = tk.Canvas(aBaF, width = 120, height = 40, bg = "purple")
def load(goTo, ms):
load = tk.Tk()
loadImage = tk.Canvas(load, height = 300, width = 300, bg = "black")
loadImage.pack()
loadImage.create_oval(125, 130, 175, 180, fill = "white")
loadImage.create_oval(130, 140, 170, 150, fill = "black")
loadImage.create_oval(130, 140, 171, 151, fill = "white")
loadImage.create_oval(152, 140, 148, 150, fill = "black")
load.after(ms, lambda: [goTo(), load.destroy()])
load(homescreen, 1)
如果您的程序代表一个应用程序,则只生成一个
Tk
实例。在Tk
对象表示整个应用程序的根,通过删除它并创建另一个应用程序,实际上是在创建一个单独的应用程序,对以前的应用程序的任何引用都会导致未定义的行为,例如崩溃python。在不要使用
Tk
作为单独的窗口,而是使用Toplevel
,因为这正是它们的目的,单独的窗口。在通过将程序中所有出现的
tk.Tk()
替换为tk.Toplevel(abs_root)
,然后将abs_root
定义为tk.Tk()
,如下所示:将使您的程序正常工作,但是它确实意味着它将运行到
abs_root
被破坏之前,这不能通过单击关闭按钮来实现,因为它没有显示为一个窗口,您要么必须使用某种条件显式调用abs_root.destroy()
,要么选择一个将是第一个创建并最后关闭的窗口并使用它改为abs_root
。(在编写程序时不可能使用)相关问题 更多 >
编程相关推荐