【问题标题】:Python tkinter downsizing widgetsPython tkinter 缩小小部件
【发布时间】:2019-09-23 22:18:02
【问题描述】:

我查看了所有其他问题和答案,但找不到适合我正在尝试做的事情。

代码:

class GameWin:
    def __init__(self, master):
        self.master = master
        self.master.title("Title")

        self.main_frame = Frame(self.master, bd = 10, bg = uni_bg)
        self.main_frame.grid()

        self.left_frame = Frame(self.main_frame, bd = 10, bg = uni_bg)
        self.left_frame.grid(column = 0, row = 0)

        self.right_frame = Frame(self.main_frame, bd = 10, bg = uni_bg)
        self.right_frame.grid(column = 1, row = 0)

        self.right_frame.columnconfigure(0, weight = 1)
        self.right_frame.rowconfigure(0, weight = 1)
        self.right_frame.columnconfigure(1, weight = 1)
        self.right_frame.rowconfigure(1, weight = 1)

        self.web = Text(self.left_frame, font = (uni_font, 12), wrap = WORD, bg = uni_bt_bg, fg = uni_fg)
        self.web.grid(column = 0, row = 0, padx = 5, pady = 5)

        self.output = Text(self.left_frame, font = (uni_font, 12), wrap = WORD, bg = "black", fg = uni_fg)
        self.output.grid(column = 0, row = 1, padx = 5, pady = 5, sticky = "ew")
        self.output.configure(state = "disabled")

        self.input = Entry(self.left_frame, font = (uni_font, 12))
        self.input.grid(column = 0, row = 2, sticky = "ew")
        self.input.bind('<Return>', self.submit)

        self.notepad = Text(self.right_frame, font = (uni_font, 12), wrap = WORD, bg = uni_fg, fg = "black", width = 42)
        self.notepad.grid(column = 0, row = 0, pady = 5, rowspan = 2)

        self.sys_info = Text(self.right_frame, font = (uni_font, 12), wrap = WORD, bg = uni_bg, fg = uni_fg, width = 35, height = 11, bd = 0)
        self.sys_info.tag_configure('center', justify='center')
        self.sys_info.grid(column = 1, row = 0, pady = 5)
        self.sys_info.insert(END, "NAME", "center")
        self.sys_info.configure(state = "disabled")

        self.trace = Text(self.right_frame, font = (uni_font, 12), wrap = WORD, bg = uni_bg, fg = uni_fg, width = 35, height = 11)
        self.trace.grid(column = 1, row = 1, pady = 5)

        self.email = Text(self.right_frame, font = (uni_font, 12), wrap = WORD, bg = uni_bt_bg, fg = uni_fg)
        self.email.grid(column = 0, row = 2, pady = 5, columnspan = 2)
        self.email.configure(state = "disabled")

        self.respond = Entry(self.right_frame, font = (uni_font, 12))
        self.respond.grid(column = 0, row = 3, columnspan = 2, sticky = "ew")
        self.respond.bind('<Return>', self.do_respond)

    def submit(self, event):
        self.output.configure(state = "normal")
        self.output.configure(state = "disabled")
        pass

    def do_respond(self, event):
        pass

当前屏幕图片:https://i.imgur.com/P2B6E5y.png

我要弄清楚的第一件事是如何不明确说明右上角的 3 个文本小部件的大小。因为每个人的屏幕大小不一样。如果我没有明确说明大小,它们会扩展并且一切都会变得古怪(因为默认文本小部件很大)。我希望小部件自动缩小以适合列(与大灰色右下角文本小部件的宽度相同)。这甚至可能吗?

其次是让框架和小部件填满窗口中的所有空间。无论是全屏(如图所示)还是较小的窗口(并希望保持它们的大小相对)。窗户边缘有很多空白空间,我想摆脱它。我已经尝试了所有我能想到的方法,但我无法让它们填补那个空间。

我尝试将前 3 个小部件分别放在它们自己的框架中,限制相对于窗口大小的框架大小,并将小部件设置为填充该框架,但它不起作用。我曾经尝试过的代码:https://pastebin.com/3YWK9Xg2

class GameWin:
    def __init__(self, master):
        self.master = master
        self.master.title("Hacker")
        win_width = self.master.winfo_width()
        win_height = self.master.winfo_height()

        self.main_frame = Frame(self.master, bd = 10, bg = uni_bg)
        self.main_frame.grid(sticky = "nsew")

        self.left_frame = Frame(self.main_frame, bd = 10, bg = uni_bg, height = int(win_height), width = int(win_width/2))
        self.left_frame.grid(column = 0, row = 0, rowspan = 3)
        self.left_frame.grid_propagate(False)

        self.note_frame = Frame(self.main_frame, bd = 10, bg = uni_bg, height = int(win_height/2), width = int(win_width/4))
        self.note_frame.grid(column = 1, row = 0, rowspan = 2, sticky = "n")
        self.note_frame.grid_propagate(False)

        self.sys_frame = Frame(self.main_frame, bd = 10, bg = uni_bg, height = int(win_height/4), width = int(win_width/4))
        self.sys_frame.grid(column = 2, row = 0, sticky = "n")
        self.sys_frame.grid_propagate(False)

        self.trace_frame = Frame(self.main_frame, bd = 10, bg = uni_bg, height = int(win_height/4), width = int(win_width/4))
        self.trace_frame.grid(column = 2, row = 1, sticky = "n")
        self.trace_frame.grid_propagate(False)

        self.bottom_right_frame = Frame(self.main_frame, bd = 10, bg = uni_bg, height = int(win_height/2), width = int(win_width/2))
        self.bottom_right_frame.grid(column = 1, row = 2, columnspan = 2)
        self.bottom_right_frame.grid_propagate(False)

        self.web = Text(self.left_frame, font = (uni_font, 12), wrap = WORD, bg = uni_bt_bg, fg = uni_fg)
        self.web.grid(column = 0, row = 0, padx = 5, pady = 5)

        self.output = Text(self.left_frame, font = (uni_font, 12), wrap = WORD, bg = "black", fg = uni_fg)
        self.output.grid(column = 0, row = 1, padx = 5, pady = 5, sticky = "ew")


        self.input = Entry(self.left_frame, font = (uni_font, 12))
        self.input.grid(column = 0, row = 2, sticky = "ew")
        self.input.bind('<Return>', self.submit)

        self.notepad = Text(self.note_frame, font = (uni_font, 12), wrap = WORD, bg = uni_fg, fg = "black")
        self.notepad.pack(fill = BOTH, expand = YES)

        self.sys_info = Text(self.sys_frame, font = (uni_font, 12), wrap = WORD, bg = uni_bg, fg = uni_fg)
        self.sys_info.tag_configure('center', justify='center')
        self.sys_info.grid(sticky = "nsew")
        self.sys_info.insert(END, "NAME", "center")
        self.sys_info.configure(state = "disabled")

        self.trace = Text(self.trace_frame, font = (uni_font, 12), wrap = WORD, bg = uni_bg, fg = uni_fg)
        self.trace.grid(sticky = "nsew")

        self.email = Text(self.bottom_right_frame, font = (uni_font, 12), wrap = WORD, bg = uni_bt_bg, fg = uni_fg)
        self.email.grid(row = 0, pady = 5, columnspan = 2, sticky = "nsew")
        self.email.configure(state = "disabled")

        self.respond = Entry(self.bottom_right_frame, font = (uni_font, 12))
        self.respond.grid(row = 1, columnspan = 2, sticky = "ew")
        self.respond.bind('<Return>', self.do_respond)

    def submit(self, event):
        self.output.configure(state = "normal")
        self.output.configure(state = "disabled")

    def do_respond(self, event):
        pass

和结果图片:https://i.imgur.com/IVnw65x.png

这里是完整代码:https://pastebin.com/Gm2ePqFH。我希望它看起来像在第一张图片中,而不必明确说明每个文本小部件的大小。我想让它相对于窗口保持相同的大小。

【问题讨论】:

  • 请提供minimal reproducible example。我们无法运行您发布的代码。它缺少许多全局变量定义。
  • 我强烈建议您在给定框架内将所有对grid 的呼叫组合在一起。小部件创建和小部件布局交错使您很难在代码中看到布局。
  • 好的,添加完整的代码。
  • 你是什么意思“在给定的框架内对网格的所有调用进行分组”?我以前从未听说过有电话。我也不确定“交错小部件创建和小部件布局”是什么意思。这是代码的哪一部分?
  • 您的所有代码都执行交错。您创建一个小部件。然后你叫网格。然后你创建另一个小部件。然后你叫网格。然后你创建另一个小部件。然后你叫网格。相反,将所有对 grid 的调用移动到一个组中:创建一个小部件,创建一个小部件,创建一个小部件,创建一个小部件,网格,网格,网格,网格。

标签: python tkinter widget resize downsize


【解决方案1】:

如果您希望小部件缩小到列的大小,最适合我的策略是使小部件非常小,然后使用布局管理器(packplace 或 @987654323 @) 使它们更大以适应。如果这确实是您可以接受的最小尺寸,您可以将小部件设置为 1x1,或者您可以将其设置为您认为的绝对最小值(例如,4 行 20 个字符、20 行 10 个字符等)。

因此,首先要使这些小部件尽可能小。

接下来,确保使用sticky 属性,以便小部件增长以填充其分配的空间。您还需要确保为self.right_frame 使用sticky 属性,以便它也填充其空间。

最后,确保调用rowconfigurecolumnconfigure 为任何具有grid 管理的子级的小部件设置正权重。你不是为self.master 这样做,也不是为self.left_frameself.right_frame 这样做

根据经验,如果您只在一个框架中放置一个或两个小部件,并且您希望这些小部件填充框架,那么使用 pack 比使用 grid 好得多,因为您没有不必记住给行和列权重。

例如,您可以使用pack 来管理左右帧。您也可以使用packGameWin 放在它的主人里面。

另外,不要试图一次解决所有的布局问题。在你的情况下,我会这样解决这个问题:

  • 从您的mainframe 开始并获取它以填充包含窗口。确保您手动调整窗口大小以观察它的大小。

  • 接下来,添加左右框架。确保它们增长和缩小以适应 mainframe

  • 接下来,只关注左侧框架中的小部件。添加它们,并确保它们缩小并适合。

  • 然后,将焦点放在右侧框架上。添加它们,并确保它们缩小并适合。

最后,提个建议。将您对grid 的呼叫组合在一起。现在编写代码时,您需要修复散布在整个文件中的一大堆行。通过一些重组,您需要更改的几乎所有代码行都将在一个代码块中。

例如,而不是这个:

self.web = Text(...)
self.web.grid(...)
self.output = Text(...)
self.output.grid(...)
self.input = Text(...)
self.input.grid(...)
self.notepad = Text(...)
self.notepad.grid(...)

这样做:

self.web = Text(...)
self.output = Text(...)
self.input = Text(...)
self.notepad = Text(...)

self.web.grid(...)
self.output.grid(...)
self.input.grid(...)
self.notepad.grid(...)

这样,您一眼就能回答“我的小部件是如何定义的?”和“我的小部件是如何布局的”的问题。以你现在的方式,这些问题很难回答。

【讨论】:

    猜你喜欢
    • 2019-12-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-10-30
    • 2019-01-03
    • 2014-12-17
    相关资源
    最近更新 更多