Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/user-interface/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python Tkinter GUI框架-使用';在';之后;?_Python_User Interface_Tkinter_Frames - Fatal编程技术网

Python Tkinter GUI框架-使用';在';之后;?

Python Tkinter GUI框架-使用';在';之后;?,python,user-interface,tkinter,frames,Python,User Interface,Tkinter,Frames,我一直在试验我在这里找到的一些代码,这些代码允许您在多个tkinterGUI框架之间导航: 我试着看看是否可以在经过一定时间后自动加载特定帧(类似于睡眠屏幕/屏幕保护程序) 我使用了.after方法,并在frame.tkraise()之后开始。它调用了一个名为Autoload的新类,该类目前只是主应用类SeaofBTCapp的副本 它可以工作,但明显的问题是它会弹出框架到一个新窗口中,因为它再次调用: tk.Tk.__init__(self, *args, **kwargs) 我是个十足的新

我一直在试验我在这里找到的一些代码,这些代码允许您在多个tkinterGUI框架之间导航:

我试着看看是否可以在经过一定时间后自动加载特定帧(类似于睡眠屏幕/屏幕保护程序)

我使用了.after方法,并在
frame.tkraise()之后开始。它调用了一个名为
Autoload
的新类,该类目前只是主应用类
SeaofBTCapp
的副本

它可以工作,但明显的问题是它会弹出框架到一个新窗口中,因为它再次调用:

tk.Tk.__init__(self, *args, **kwargs)
我是个十足的新手,所以我很抱歉问了一个非常明显的问题,但是什么是防止它突然出现的最好方法呢?如果我从其中一个框架类复制代码,它会告诉我
\uuuu init\uuu
没有获得足够的参数。我尝试过各种(显而易见的)方法,但我很难理解这一点,因为它最终必须是一个在主应用程序后面运行的被动功能,而不会妨碍其他功能(调用新框架)。我可能只是想得太多了,错过了一个非常简单而优雅的解决方案。有什么想法吗

这是完整的代码,谢谢你的帮助

import Tkinter as tk

LARGE_FONT= ("Verdana", 12)

class SeaofBTCapp(tk.Tk):

    def __init__(self, *args, **kwargs):

        tk.Tk.__init__(self, *args, **kwargs)
        container = tk.Frame(self)

        container.pack(side="top", fill="both", expand = True)

        container.grid_rowconfigure(0, weight=1)
        container.grid_columnconfigure(0, weight=1)

        self.frames = {}

        for F in (StartPage, PageOne, PageTwo):

            frame = F(container, self)

            self.frames[F] = frame

            frame.grid(row=0, column=0, sticky="nsew")

        self.show_frame(StartPage)


    def show_frame(self, cont):

        frame = self.frames[cont]
        frame.tkraise()
        frame.after(2000, Autoload)  #####


class Autoload(tk.Tk):

    def __init__(self, *args, **kwargs):

        tk.Tk.__init__(self, *args, **kwargs)
        container = tk.Frame(self)

        container.pack(side="top", fill="both", expand = True)

        container.grid_rowconfigure(0, weight=1)
        container.grid_columnconfigure(0, weight=1)

        self.frames = {}

        for F in (StartPage, PageOne, PageTwo):

            frame = F(container, self)

            self.frames[F] = frame

            frame.grid(row=0, column=0, sticky="nsew")

        self.show_frame(StartPage)


    def show_frame(self, cont):

        frame = self.frames[cont]
        frame.tkraise()
        frame.after(2000, Autoload)  #####


class StartPage(tk.Frame):

    def __init__(self, parent, controller):
        tk.Frame.__init__(self,parent)
        label = tk.Label(self, text="Start Page", font=LARGE_FONT)
        label.pack(pady=10,padx=10)

        button = tk.Button(self, text="Visit Page 1",
                            command=lambda: controller.show_frame(PageOne))
        button.pack()

        button2 = tk.Button(self, text="Visit Page 2",
                            command=lambda: controller.show_frame(PageTwo))
        button2.pack()


class PageOne(tk.Frame):

    def __init__(self, parent, controller):
        tk.Frame.__init__(self, parent)
        label = tk.Label(self, text="Page One!!!", font=LARGE_FONT)
        label.pack(pady=10,padx=10)

        button1 = tk.Button(self, text="Back to Home",
                            command=lambda: controller.show_frame(StartPage))
        button1.pack()

        button2 = tk.Button(self, text="Page Two",
                            command=lambda: controller.show_frame(PageTwo))
        button2.pack()


class PageTwo(tk.Frame):

    def __init__(self, parent, controller):
        tk.Frame.__init__(self, parent)
        label = tk.Label(self, text="Page Two!!!", font=LARGE_FONT)
        label.pack(pady=10,padx=10)

        button1 = tk.Button(self, text="Back to Home",
                            command=lambda: controller.show_frame(StartPage))
        button1.pack()

        button2 = tk.Button(self, text="Page One",
                            command=lambda: controller.show_frame(PageOne))
        button2.pack()



app = SeaofBTCapp()
app.mainloop()

你希望自动加载能做什么?复制代码似乎没有什么意义-难道你不能在SeaOfBTCapp中创建一个函数,通过init和autoload调用它吗?嗨,谢谢,我正在尝试制作一个“睡眠屏幕”类型的框架,它可能在30秒后出现,而不会中断任何功能或重新启动代码。我的GUI将正常工作,每次操作(按钮命令)后30秒计数将重新开始。如果在30秒内(从.after开始)没有按下任何按钮,GUI将“进入睡眠”,但它只是一个空白的黑框(黑色按钮模拟黑屏),单击后返回主菜单。我可以在SeaOfBTCapp中创建一个函数,但在扩展gui时,我会尝试确保此睡眠方法在全局范围内工作。。。也就是说,我可能必须为每个类(菜单页)添加一个函数。我同意,但这是最有效的执行方式吗?任何例子都会非常有用,我想得越深我就越迷茫。我在谷歌上搜索过,很惊讶我没能找到任何人尝试这样的事情。谢谢你希望自动加载能做什么?复制代码似乎没有什么意义-难道你不能在SeaOfBTCapp中创建一个函数,通过init和autoload调用它吗?嗨,谢谢,我正在尝试制作一个“睡眠屏幕”类型的框架,它可能在30秒后出现,而不会中断任何功能或重新启动代码。我的GUI将正常工作,每次操作(按钮命令)后30秒计数将重新开始。如果在30秒内(从.after开始)没有按下任何按钮,GUI将“进入睡眠”,但它只是一个空白的黑框(黑色按钮模拟黑屏),单击后返回主菜单。我可以在SeaOfBTCapp中创建一个函数,但在扩展gui时,我会尝试确保此睡眠方法在全局范围内工作。。。也就是说,我可能必须为每个类(菜单页)添加一个函数。我同意,但这是最有效的执行方式吗?任何例子都会非常有用,我想得越深我就越迷茫。我在谷歌上搜索过,很惊讶我没能找到任何人尝试这样的事情。谢谢