tkinter pack_forget vs Window 默认中心位置

tkinter pack_forget vs Window default center position

我有一个包含多个 windows 的应用。我使用 pack_forget 来消除登录 window 并调用主要 window。但是这个 main window 失去了 tkinter 的默认居中位置。 window 在位置 (0 , 0) 创建。

有没有什么简单的方法可以让这个主要window创建在默认的居中位置?

示例代码,3 个文件 ->

main.py

#!/usr/bin/env python3

from tkinter import *
from frm_login import Wlogin

class Mainframe(Tk):
    def __init__(self):
        Tk.__init__(self)
        self.frame = Wlogin(self)
        self.frame.pack()

    def change(self, frame):
        self.frame.pack_forget() # delete currrent frame
        self.frame = frame(self)
        self.frame.pack() # make new frame


if __name__== '__main__':
    app = Mainframe()
    app.mainloop()

frm_login.py

from tkinter import *
from frm_default import Wmain

class Func(Frame):
    def check(self, event=None):
        if self.pwd.get() == '1':
            self.master.change(Wmain)
        else:
            self.status.config(text='wrong password')


class Wlogin(Func):
    def __init__(self, master=None, **kwargs):
        Frame.__init__(self, master, **kwargs)

        master.title('Enter password')
        master.geometry('300x200')

        self.status = Label(self, fg='red')
        self.status.pack()

        self.lbl = Label(self, text='Enter password')
        self.lbl.pack()

        self.pwd = Entry(self, show='*')
        self.pwd.insert(-1, '1')
        self.pwd.pack()
        self.pwd.focus()
        self.pwd.bind('<Return>', self.check)
        self.pwd.bind('<KP_Enter>', self.check)

        self.btn = Button(self, text='Done', command=self.check)
        self.btn.pack()

        self.btn = Button(self, text='Cancel', command=self.quit)
        self.btn.pack()

frm_default.py

from tkinter import *

class Wmain(Frame):
    def __init__(self, master=None, **kwargs):
        Frame.__init__(self, master, **kwargs)
        master.title('Main application')
        master.geometry('600x400')

您的遗忘/重新打包代码并没有使它独一无二。您可以使用与其他方式相同的命令。所以要么自己定义位置:

master.geometry('600x400+300+400')

或者使用 tk PlaceWindow 函数:

master.eval('tk::PlaceWindow . center')

或者根据window尺寸和显示器尺寸计算位置:

master.geometry("600x400")
master.update_idletasks()
x = (master.winfo_screenwidth() - master.winfo_reqwidth()) // 2
y = (master.winfo_screenheight() - master.winfo_reqheight()) // 2
master.geometry(f"+{x}+{y}")

FWIW,我的经验告诉我,自己设置 window 大小而不是让 tkinter 计算它会导致错误。