tkinter 中的“权重”有什么作用?

问题描述 投票:0回答:2

我一直在搜索不同的网站,试图找出权重在 tkinter 中的作用。我从 TkDocs 得到这个:

每一列和行都有一个与之关联的“权重”网格选项,它告诉它如果母版中有额外的空间需要填充,它应该增长多少。默认情况下,每列或行的权重为 0,这意味着不会扩展以填充空间。

有人可以帮我把这个放在一些上下文中吗,因为我正在努力理解它的作用。我已经尝试过以下代码,当我更改值时,它似乎只是在页面上移动内容。

try:
    import tkinter
except ImportError:  # python 2
    import Tkinter as tkinter

import os

mainWindow = tkinter.Tk()

mainWindow.title("Grid demo")
mainWindow.geometry('640x480-8-200')

label = tkinter.Label(mainWindow, text="tkinter grid demo")
label.grid(row=0, column=0, columnspan=3)

mainWindow.columnconfigure(0, weight=1)
mainWindow.columnconfigure(1, weight=1)
mainWindow.columnconfigure(2, weight=3)
mainWindow.columnconfigure(3, weight=3)
mainWindow.columnconfigure(4, weight=3)
mainWindow.rowconfigure(0, weight=1)
mainWindow.rowconfigure(1, weight=10)
mainWindow.rowconfigure(2, weight=1)
mainWindow.rowconfigure(3, weight=3)
mainWindow.rowconfigure(4, weight=3)

fileList = tkinter.Listbox(mainWindow)
fileList.grid(row=1, column=0, sticky='nsew', rowspan=2)
fileList.config(border=2, relief='sunken')

for zone in os.listdir('/Windows/System32'):
    fileList.insert(tkinter.END, zone)
mainWindow.mainloop()
python tkinter
2个回答
119
投票

用最简单的术语来说,如果有额外的空间,非零权重会导致行或列增长。默认权重为零,这意味着如果有额外空间,列将不会增长。

考虑以下代码,它创建一个比内部小部件更大的窗口,并且没有列具有权重:

import tkinter as tk

root = tk.Tk()
root.geometry("200x100")

f1 = tk.Frame(root, background="bisque", width=10, height=100)
f2 = tk.Frame(root, background="pink", width=10, height=100)

f1.grid(row=0, column=0, sticky="nsew")
f2.grid(row=0, column=1, sticky="nsew")

root.grid_columnconfigure(0, weight=0)
root.grid_columnconfigure(1, weight=0)

root.mainloop()

注意:

columnconfigure
grid_columnconfigure
的别名。我在这里使用了较长的形式,因为我认为它更清晰。

这就是窗口的样子:

window with no weights applied

它看起来像这样的原因是因为 tkinter 被告知不要给任何列任何额外的空间,所以额外的空间在右边没有被使用。

现在,更改代码,以便我们只为一列赋予权重:

root.grid_columnconfigure(0, weight=1)

当我们重新启动时,我们现在有一个如下所示的窗口:

window with weight on first column only

发生什么事了?由于第 0 列的权重为 1,因此 tkinter 为该列提供了额外的空间。您可以将权重设置为 1、100、100000,您会得到相同的结果。在这种情况下,所有额外空间都会进入这一列。

如果给两列都赋予权重,会发生什么?额外的空间按照其重量按比例分配在各列之间。例如,假设您希望左侧的导航区域占据屏幕的 1/4,而主区域应占据屏幕的 3/4(比例为 1:3)。

让我们将权重更改为如下所示:

root.grid_columnconfigure(0, weight=1)
root.grid_columnconfigure(1, weight=3)

由于两列都有重量,因此为两列提供了额外的空间。对于每四个像素的额外空间,第 0 列将获得 1,第 1 列将获得其他 3。

window with weight given to both columns

更重要的是,如果您以交互方式调整窗口大小,则会尽可能保留比例。这是我手动调整大小以使其更宽的同一个窗口:

window after resizing


0
投票

这只是比率。如果您有两列,例如

column1
column2
,并且将
column1
的权重设置为
3
,将
column2
设置为
5
,则
column1
会采用
3 / (3 + 5)
column2
会采用
5 / (3 + 5)
可用空间。如果将它们设置为零,它们根本不会扩展以填充空间,这是默认设置。

提示:权重参数必须为整数类型。

© www.soinside.com 2019 - 2024. All rights reserved.