Вкажіть відносну ширину двох вбудованих "записів" у віджеті "text"

У мене є проблема у визначенні розміру віджета Entry у Linux і Windows. Ці записи були створені на Linux:

http://i56.tinypic.com/2edaaeg.png

У Linux вони відмінно виглядають у текстовому віджеті. Є 2 клітинки для запису один за одним, створені за допомогою цього рядка коду:

tk.Entry (master, width = 16)

Ширина визначається як 16 символів.

Однак на Windows клітини займають лише половину простору, і я повинен вказати ширину 22, тому що розмір шрифту менший у Windows.

Моє питання: чи є спосіб вказати відносну ширину цих двох клітин у віджеті Текст, так що кожна клітина займає 1/2 від батьківського віджета?

1

1 Відповіді

Within a text widget? No, there is no direct support for relative widths. within a frame? yes. If you are putting them in a text widget (I presume, so you can scroll them) you have to manage the widths yourself. You can add a binding to the event of the text widget. This fires when the text widget changes size, and you can resize all the widgets at that point.

Найпростіше - помістити їх у кадр за допомогою сітки , а потім покласти кадр на полотно, щоб прокрутити його.

Ось приклад:

import Tkinter as tk

class SampleApp(tk.Tk):
    def __init__(self, *args, **kwargs):
        tk.Tk.__init__(self, *args, **kwargs)
        self.canvas = tk.Canvas(self, width=200, highlightthickness=0)
        self.vsb = tk.Scrollbar(orient="vertical", command=self.canvas.yview)
        self.canvas.configure(yscrollcommand=self.vsb.set)
        self.vsb.pack(side="right", fill="y")
        self.canvas.pack(side="left", fill="both", expand=True)

        self.container = tk.Frame(self.canvas, borderwidth=0, highlightthickness=0)
        self.container.grid_columnconfigure(0, weight=1)
        self.container.grid_columnconfigure(1, weight=1)
        for i in range(30):
            e1 = tk.Entry(self.container)
            e2 = tk.Entry(self.container)
            e1.grid(row=i, column=0,sticky="ew")
            e2.grid(row=i, column=1,sticky="ew")
            e1.insert(0, "find %s" % i)
            e2.insert(0, "replace %s" % i)

        self.canvas.create_window((0,0), anchor="nw", window=self.container, tags="container")
        self.canvas.configure(scrollregion=self.canvas.bbox("all"))
        self.canvas.bind("", self.OnCanvasConfigure)

    def OnCanvasConfigure(self, event):
        self.canvas.itemconfigure("container", width=event.width)
        self.canvas.configure(scrollregion=self.canvas.bbox("all"))

if __name__ == "__main__":
    app = SampleApp()
    app.mainloop()
1
додано
Спасибі, Брайан - знову :) Я дійсно дійсно боровся з цим віджетом, але я сподіваюся, що це тепер завершено для того, що мені потрібно.
додано Автор marw, джерело