Python基礎=== Tkinter Grid布局管理器詳解


本文轉自:https://www.cnblogs.com/ruo-li-suo-yi/p/7425307.html          @ 箬笠蓑衣

 

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