Python Tkinter Grid布局管理器詳解


Grid(網格)布局管理器會將控件放置到一個二維的表格里。主控件被分割成一系列的行和列,表格中的每個單元(cell)都可以放置一個控件。

注意:不要試圖在一個主窗口中混合使用pack和grid

(1)標簽控件

1 from tkinter import *
2 
3 tk=Tk()
4 #標簽控件,顯示文本和位圖,展示在第一行
5 Label(tk,text="First").grid(row=0)
6 Label(tk,text="Second").grid(row=1)#第二行
7 
8 #主事件循環
9 mainloop()

(2) 輸入控件

 1 from tkinter import *
 2 
 3 tk=Tk()
 4 #標簽控件,顯示文本和位圖,展示在第一行
 5 Label(tk,text="First").grid(row=0)
 6 Label(tk,text="Second").grid(row=1)#第二行
 7 
 8 #輸入控件
 9 Entry(tk).grid(row=0,column=1)
10 Entry(tk).grid(row=1,column=1)
11 
12 #主事件循環
13 mainloop()

(3)sticky參數的使用

 1 from tkinter import *
 2 
 3 tk=Tk()
 4 #標簽控件,顯示文本和位圖,展示在第一行
 5 Label(tk,text="First").grid(row=0,sticky=E)#靠右
 6 Label(tk,text="Second").grid(row=2,sticky=W)#第二行,靠左
 7 
 8 #輸入控件
 9 Entry(tk).grid(row=0,column=1)
10 Entry(tk).grid(row=2,column=1)
11 
12 #主事件循環
13 mainloop()

(4)columnspan和rowspan參數的使用

columnspan選項可以指定控件跨越多列顯示,而rowspan選項同樣可以指定控件跨越多行顯示。

 1 from tkinter import *
 2 
 3 tk=Tk()
 4 var=IntVar()
 5 
 6 #標簽控件,顯示文本和位圖,展示在第一行
 7 Label(tk,text="First").grid(row=0,sticky=E)#靠右
 8 Label(tk,text="Second").grid(row=1,sticky=W)#第二行,靠左
 9 
10 #輸入控件
11 Entry(tk).grid(row=0,column=1)
12 Entry(tk).grid(row=1,column=1)
13 
14 button=Checkbutton(tk,text="Precerve aspect",variable=var)
15 button.grid(sticky=W)
16 
17 #主事件循環
18 mainloop()

跨越兩列顯示如下

 1 from tkinter import *
 2 
 3 tk=Tk()
 4 var=IntVar()
 5 
 6 #標簽控件,顯示文本和位圖,展示在第一行
 7 Label(tk,text="First").grid(row=0,sticky=E)#靠右
 8 Label(tk,text="Second").grid(row=1,sticky=W)#第二行,靠左
 9 
10 #輸入控件
11 Entry(tk).grid(row=0,column=1)
12 Entry(tk).grid(row=1,column=1)
13 
14 button=Checkbutton(tk,text="Precerve aspect",variable=var)
15 button.grid(columnspan=2,sticky=W)
16 
17 #主事件循環
18 mainloop()

 1 from tkinter import *
 2 
 3 tk=Tk()
 4 var=IntVar()
 5 
 6 #標簽控件,顯示文本和位圖,展示在第一行
 7 Label(tk,text="First").grid(row=0,sticky=E)#靠右
 8 Label(tk,text="Second").grid(row=1,sticky=W)#第二行,靠左
 9 
10 #輸入控件
11 Entry(tk).grid(row=0,column=1)
12 Entry(tk).grid(row=1,column=1)
13 
14 #多選框插件
15 button=Checkbutton(tk,text="Precerve aspect",variable=var)
16 button.grid(row=2,columnspan=2,sticky=W)
17 
18 #插入圖片
19 photo=PhotoImage(file="python_logo.gif")
20 label=Label(image=photo)
21 label.image=photo
22 label.grid(row=0,column=2)
23 
24 #主事件循環
25 mainloop()

 1 from tkinter import *
 2 
 3 tk=Tk()
 4 var=IntVar()
 5 
 6 #標簽控件,顯示文本和位圖,展示在第一行
 7 Label(tk,text="First").grid(row=0,sticky=E)#靠右
 8 Label(tk,text="Second").grid(row=1,sticky=W)#第二行,靠左
 9 
10 #輸入控件
11 Entry(tk).grid(row=0,column=1,padx=10,pady=10)
12 Entry(tk).grid(row=1,column=1)
13 
14 #多選框插件
15 button=Checkbutton(tk,text="Precerve aspect",variable=var)
16 button.grid(row=2,columnspan=2,sticky=W)
17 
18 #插入圖片
19 photo=PhotoImage(file="python_logo.gif")
20 label=Label(image=photo)
21 label.image=photo
22 label.grid(row=0,column=2,rowspan=2,columnspan=2,
23            sticky=W+E+N+S, padx=5, pady=5)#合並兩行,兩列,居中,四周外延5個長度
24 
25 #主事件循環
26 mainloop()

(5)

 1 from tkinter import *
 2 
 3 tk=Tk()
 4 var=IntVar()
 5 
 6 #標簽控件,顯示文本和位圖,展示在第一行
 7 Label(tk,text="First").grid(row=0,sticky=E)#靠右
 8 Label(tk,text="Second").grid(row=1,sticky=W)#第二行,靠左
 9 
10 #輸入控件
11 Entry(tk).grid(row=0,column=1,padx=10,pady=10)
12 Entry(tk).grid(row=1,column=1)
13 
14 #多選框插件
15 button=Checkbutton(tk,text="Precerve aspect",variable=var)
16 button.grid(row=2,columnspan=2,sticky=W)
17 
18 #插入圖片
19 photo=PhotoImage(file="python_logo.gif")
20 label=Label(image=photo)
21 label.grid(row=0,column=2,rowspan=2,columnspan=2,
22            sticky=W+E+N+S, padx=5, pady=5)#合並兩行,兩列,居中,四周外延5個長度
23 
24 #按鈕控件
25 button1=Button(tk,text="Zoom in")
26 button1.grid(row=2,column=2)
27 button2=Button(tk,text="Zoom out")
28 button2.grid(row=2,column=3)
29 
30 
31 #主事件循環
32 mainloop()

 (6)padx和pady參數的應用

 1 from tkinter import *
 2 import time
 3 
 4 t = Tk()
 5 t.title('與python聊天中')
 6        
 7   #創建frame容器
 8 frmLT = Frame(width=500, height=320, bg='white')
 9 frmLC = Frame(width=500, height=150, bg='red')
10 frmLB = Frame(width=500, height=30)
11 frmRT = Frame(width=200, height=500)
12 
13 frmLT.grid(row=0, column=0)
14 frmLC.grid(row=1, column=0)
15 frmLB.grid(row=2, column=0)
16 frmRT.grid(row=0, column=1, rowspan=3)

 1 from tkinter import *
 2 import time
 3 
 4 t = Tk()
 5 t.title('與python聊天中')
 6        
 7   #創建frame容器
 8 frmLT = Frame(width=500, height=320, bg='white')
 9 frmLC = Frame(width=500, height=150, bg='red')
10 frmLB = Frame(width=500, height=30)
11 frmRT = Frame(width=200, height=500)
12 
13 frmLT.grid(row=0, column=0,padx=1,pady=3)
14 frmLC.grid(row=1, column=0,padx=1,pady=3)
15 frmLB.grid(row=2, column=0)
16 frmRT.grid(row=0, column=1, rowspan=3,padx=2,pady=3)

利用padx和pady,可以將框架邊界區分開

 1 from tkinter import *
 2 import time
 3 
 4 t = Tk()
 5 t.title('與python聊天中')
 6        
 7 #創建frame容器
 8 frmLT = Frame(width=500, height=320, bg='white')
 9 frmLC = Frame(width=500, height=150, bg='red')
10 frmLB = Frame(width=500, height=30)
11 frmRT = Frame(width=200, height=500)
12 
13 frmLT.grid(row=0, column=0,padx=1,pady=3)
14 frmLC.grid(row=1, column=0,padx=1,pady=3)
15 frmLB.grid(row=2, column=0)
16 frmRT.grid(row=0, column=1, rowspan=3,padx=2,pady=3)
17 
18 '''#固定容器大小
19 frmLT.grid_propagate(0)
20 frmLC.grid_propagate(0)
21 frmLB.grid_propagate(0)
22 frmRT.grid_propagate(0)'''
23 
24 #添加按鈕
25 btnSend = Button(frmLB, text='發 送', width = 8)#在frmLB容器中添加
26 btnSend.grid(row=2,column=0)
27 btnCancel = Button(frmLB, text='取消', width = 8)
28 btnCancel.grid(row=2,column=1,sticky=E)
29 
30 #添加圖片
31 imgInfo = PhotoImage(file = "python_logo.gif")
32 lblImage = Label(frmRT, image = imgInfo)
33 lblImage.image = imgInfo
34 lblImage.grid()
35 
36 #固定容器大小
37 frmLT.grid_propagate(0)
38 frmLC.grid_propagate(0)
39 frmLB.grid_propagate(0)
40 frmRT.grid_propagate(0)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM