当窗口扩展或最大化时如何调整可滚动框架的大小?

时间:2019-03-11 02:56:26

标签: python python-3.x tkinter tkinter-canvas

当窗口扩大或最大化时,框架就是恒定的。大小是恒定的。我希望整个框架随着窗口的扩大或最大化而移动。该怎么办?

from tkinter import *

def data():
    for i in range(1000):
        if (i % 2) == 0:
            l4 = Label(frame, text="Size of rectangle:")
            l4.grid(row=i, column=0)
        en = Entry(frame)
        en.grid(row=i, column=1)
    b3 = Button(frame, text="Save")
    b3.grid(row=1001, column=0)
    b4 = Button(frame, text="Back")
    b4.grid(row=1001, column=1)

def myfunction(event):
    canvas.configure(scrollregion=canvas.bbox("all"),width=250,height=700)
def _on_mousewheel(event):
    canvas.yview_scroll(-1*(event.delta/120), "units")   

root=Tk()
sizex = 272
sizey = 707
posx  = 100
posy  = 100
root.wm_geometry("%dx%d+%d+%d" % (sizex, sizey, posx, posy))

myframe=Frame(root)
myframe.place(x=0,y=0)

canvas=Canvas(myframe)
frame=Frame(canvas)
myscrollbar=Scrollbar(myframe,orient="vertical",command=canvas.yview)
canvas.configure(yscrollcommand=myscrollbar.set)

canvas.bind_all('<MouseWheel>', lambda event: canvas.yview_scroll(int(-1*(event.delta/120)), "units"))

myscrollbar.pack(side="right",fill="y")
canvas.pack(side="left")
canvas.create_window((0,0),window=frame,anchor='nw')
frame.bind("<Configure>",myfunction)
data()
root.bind("<MouseWheel>", myfunction)
root.mainloop()

1 个答案:

答案 0 :(得分:0)

调整大小后,画布将生成一个<Configure>事件。您可以绑定到此事件,并在发生这种情况时重置内部框架的大小以匹配画布的宽度。

但是,在您的特定情况下,您有一系列堆叠的小部件,当您调整窗口大小时,这些小部件都不会增长。因此,即使您调整窗口大小,画布也不会增长。由于画布没有增长,因此该事件不会触发。

您需要为几何图形管理器使用适当的选项,以确保整个窗口层次结构适当地增长和缩小,然后添加绑定以设置内部窗口的大小。

这是一个非常基本的例子。首先创建一个画布并将其打包,以使其充满根窗口。然后,它在画布内部添加一个框架,并安排每当调整画布大小时框架的宽度就改变。

import tkinter as tk

def handle_canvas_resize(event):
    canvas.itemconfigure(window_id, width=event.width)

def handle_frame_resize(event):
    canvas.configure(scrollregion=canvas.bbox("all"))

root = tk.Tk()
canvas = tk.Canvas(root, width=200, height=200)
scrollbar = tk.Scrollbar(root, command=canvas.yview)
canvas.configure(yscrollcommand=scrollbar.set)

scrollbar.pack(side="right", fill="y")
canvas.pack(fill="both", expand=True)

inner_frame = tk.Frame(canvas, background="bisque")
window_id = canvas.create_window(2,2, window=inner_frame)
for i in range(1, 101):
    label = tk.Label(inner_frame, text="label #{}".format(i))
    label.pack(side="top", fill="x", padx=1, pady=1)

inner_frame.bind("<Configure>", handle_frame_resize)
canvas.bind("<Configure>", handle_canvas_resize)
root.after_idle(canvas.yview_moveto, 0)

root.mainloop()