繁体   English   中英

当 window 调整大小时,如何调整放置的 tkinter 小部件的大小?

[英]How do I resize placed tkinter widgets when the window is resized?

我已阅读此站点上发布的其他问题,但无法解决我的问题。 我正在开发一个 tkinter 应用程序,为了让它看起来尽可能好,我选择使用.place()在屏幕上显示小部件。 x 和 y 的值对于每个小部件都是固定的,但我希望 window 可以调整大小并且小部件可以保持相同的比例。 查看随附的代码以及 GUI 的外观

import tkinter as tk
from tkinter import messagebox


class MyClass:
    def __init__(self, root):
        self.root = root
        self.root.title("App")
        self.root.geometry("600x300")

        self.welcome_label = tk.Label(self.root, text="Welcome", justify="center", fg="blue", font=("Arial", 24))
        self.welcome_label.place(x=230, y=40)

        self.username_label = tk.Label(self.root, text="Username:")
        self.username_label.place(x=140, y=100)
        self.username_box = tk.Entry(self.root, bd=3, selectbackground="#e5e3e3")
        self.username_box.place(x=230, y=100)

        self.password_label = tk.Label(self.root, text="Password:")
        self.password_label.place(x=140, y=150)
        self.password_box = tk.Entry(self.root, bd=3, selectbackground="#e5e3e3")
        self.password_box.place(x=230, y=150)

        self.log_in_buttonn = tk.Button(self.root, text="Log In", justify="center", command=self.log_inn)
        self.log_in_buttonn.place(x=470, y=230, width=70, height=50)
        self.register_button = tk.Button(self.root, text="Register", command=self.register)
        self.register_button.place(x=100, y=230, width=70, height=50)

    def log_inn(self):
        ...
    def register(self):
        ...


if __name__ == "__main__":
    roott = tk.Tk()
    app = MyClass(roott)
    roott.mainloop()

较小的 window:

屏幕截图 1 较小的窗口

更大的 window:

屏幕截图 2 更大的窗口

正常和默认:

截图3 正常和默认

除了使用 place,您还可以使用网格几何管理器。 Tkinter 将处理所有调整大小的问题,而 output 将看起来很完美。 使用 place 获得相同的结果要困难得多,因为它接受高度硬编码的值。 网格是相对的。

在容器小部件上使用.grid_rowconfigure.grid_columnconfigure

<containter_widget>.grid_rowconfigure(<row number>, weight = <whole number>)
<containter_widget>.grid_columnconfigure(<column number>, weight = <whole number>)

解释:

Tkinter 默认为每行和每列赋予 0 的weight 这意味着如果一列没有小部件,它在屏幕上的宽度将为零。

为列赋予非零weight可确保它在屏幕上始终具有一定的宽度,即使它是空的。

如果您为第 0 列和第 1 列赋予weight 1,假设所有其他列的权重为 0(即使您调整窗口大小),这两列都将正好占用容器小部件中水平可用空间的一半。 .grid_rowconfigure工作原理类似。

使用.grid

<widget>.grid(row = <row number>, column = <column number>, sticky = <combination of n,s,e,w as a string>, rowspan = _, columnspan = _, padx = _, pady = _, ipadx = _, ipady = _)

解释:

  • 行,列:不言自明
  • 粘性:小部件应在容器小部件为其分配的空间内扩展的方向。 n, s, e, w 代表四个方向。
  • rowspan:如果你使用过.grid_rowconfigure ,你可以使用 rowspan 来告诉 tkinter 小部件应该“跨越”多少行
  • columnspan:类似于rowspan
  • padx:水平填充
  • pady:垂直填充
  • ipadx:内部水平填充
  • ipady:内部垂直填充

示例网格语句:

widget.grid(row = 0, column = 1, sticky = "nsew", rowspan = 3, columnspan = 2, padx = 5, pady = 5, ipadx = 3, ipadx = 3)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM