当窗口展开或最大化时,框架保持不变。大小是恒定的。我希望当我扩展或最大化窗口时整个框架都会移动。如何做到这一点?
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()
最佳答案
Canvas 将生成 <Configure>
调整大小时发生的事件。发生这种情况时,您可以绑定(bind)到此事件并重置内框的大小以匹配 Canvas 的宽度。
但是,在您的具体情况下,您有一系列堆叠的小部件,当您调整窗口大小时,这些小部件都不会增长。因此,即使您调整窗口大小, Canvas 也不会增大。因为 Canvas 不会增长,所以事件不会触发。
您需要对几何管理器使用适当的选项,以确保窗口的整个层次结构适本地增大和缩小,然后添加绑定(bind)以设置内部窗口的大小。
这是一个非常基本的示例。它首先创建一个 Canvas 并将其打包,以便它填充根窗口。然后,它在 Canvas 内添加一个框架,并安排框架的宽度在 Canvas 大小调整时发生变化。
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()
关于python - 当窗口展开或最大化时如何调整可滚动框架的大小?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55094665/