我在下面附加了两张图片,分别显示了我当前所获得的布局和想要在GUI顶部框架中显示的布局,忽略了中部框架和底部框架。为了使代码尽可能短,我没有在其中包含其余代码。
我的图片在左边=布局。右图=我需要的布局
from Tkinter import *
root= Tk()
topFrame = Frame(root,bg="grey")
topFrame.pack()
midFrame = Frame(root,bg="lightblue",borderwidth=2,relief=GROOVE)
midFrame.pack()
bottomFrame= Frame(root,bg="lightgreen")
bottomFrame.pack(side=BOTTOM)
label1 = Label(topFrame, text="Upload Acitivity File:")
label1.pack(padx=5, pady=10)
first_button=Button(topFrame,text="Button 1")
first_button.pack()
label2 = Label(topFrame, text="Select the Activity")
label2.pack(padx=5,pady=10,side=LEFT)
b1 = Radiobutton(topFrame, text="Walking",value=1)
b1.pack(padx=5, pady=10,side=LEFT)
b2 = Radiobutton(topFrame, text="Running",value=2)
b2.pack(padx=10, pady=10)
root.mainloop()
最佳答案
通过将GUI划分为有意义的部分并为每个部分创建框架,可以更轻松地在tkinter中对齐小部件。您可以重复此操作multiple times,直到每个子帧中的对齐都简单为止。
import Tkinter as tk
root = tk.Tk()
# Create two frames on top of each other (bg color can help debugging)
frame1 = tk.Frame(root, bg="yellow")
frame2 = tk.Frame(root, bg="blue")
frame1.pack(side=tk.TOP)
frame2.pack(side=tk.TOP)
# Place label1 and button1 side-by-side in frame1
label1 = tk.Label(frame1, text="Upload Activity File:")
label1.pack(side=tk.LEFT)
button1 = tk.Button(frame1,text="Button 1")
button1.pack(side=tk.LEFT)
# Place label2, b1 and b2 side-by-side in frame2
label2 = tk.Label(frame2, text="Select the Activity")
label2.pack(side=tk.LEFT)
b1 = tk.Radiobutton(frame2, text="Walking", value=1)
b1.pack(side=tk.LEFT)
b2 = tk.Radiobutton(frame2, text="Running", value=2)
b2.pack(side=tk.LEFT)
root.mainloop()
关于python - Python Tkinter布局管理,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/45185164/