python tkinter学习——布局
目录
- 一、pack()
- 二、grid()
- 三、place()
- 四、Frame()
正文
布局
一、pack()
pack()有以下几个常用属性:
- side
- padx
- pady
- ipadx
- ipady
- fill
- expand
1,side
side属性有四个可选值:'top'、'bottom'、'left'、'right',分别表示将控件位置设在窗口顶部中心、底部中心、左边中心、右边中心。side默认值为'top'。
2,padx、pady、ipadx、ipady
这四个属性分别设置控件水平方向外边距、竖直方向外边距、水平方向内边距、竖直方向内边距。
3,fill
fill属性有四个可选值:'none'、'x'、'y'、'both'。分别表示不填充、将控件沿水平方向填充、将控件沿竖直方向填充、将控件沿水平和竖直方法填充。
当side属性被设为'top'、'bottom'时,fill只能沿水平方向填充;当side属性被设为'left'、'right'时,fill只能沿竖直方向填充。
4,expand
expand属性有两个可选值:0、1(或者'yes'、'no')。expand默认值为0。
当expand属性为0时,前面所说的side、fill一切正常;当expand属性为1时,side属性无效,此时控件会在窗口中心位置,且fill既可沿水平方向填充,也可沿竖直方向填充。
二、grid()
grid()有以下几个常用属性:
- row
- column
- padx
- pady
- ipadx
- ipady
- rowspan
- columnspan
- sticky
1,row、column
grid()将窗口看做一张表格,将控件放在其中的单元格中,而row、column则用来设置控件所在单元格的坐标。
例如:
#文件名:test.py
import tkinter as tk
window = tk.Tk()
window.title('test')
window.geometry('400x400')
btn1 = tk.Button(window,text='one',width=5,bg='green')
btn1.grid(row=0,column=0)
btn2 = tk.Button(window,text='two',width=5,height=5,bg='red')
btn2.grid(row=0,column=1)
btn3 = tk.Button(window,text='three',width=3,height=3,bg='blue')
btn3.grid(row=1,column=0)
btn4 = tk.Button(window,text='four',width=15,height=10,bg='yellow')
btn4.grid(row=1,column=1)
window.mainloop()
效果如图:
从图中我们可以看出,单元格的宽度、高度是由同一列中最宽、同一行中最高的控件的宽高决定的。
2,padx、pady、ipadx、ipady
这四个属性分别设置控件水平方向外边距、竖直方向外边距、水平方向内边距、竖直方向内边距。
3,rowspan、columnspan
有时候,一个控件可能会占用不止一个单元格,这时就要用到rowspan、columnspan,他们的作用与合并单元格类似。
rowspan=3表示该控件会在竖直方向占用3行单元格;column=3则报表时该控件会在水平方向占用3列单元格。
现在我们对test.py做些改动,让绿色按钮占用2x2个单元格:
#文件名:test.py
import tkinter as tk
window = tk.Tk()
window.title('test')
window.geometry('400x400')
btn1 = tk.Button(window,text='one',width=5,bg='green')
btn1.grid(row=0,column=0,rowspan=2,columnspan=2)
btn2 = tk.Button(window,text='two',width=5,height=5,bg='red')
btn2.grid(row=0,column=1)
btn3 = tk.Button(window,text='three',width=3,height=3,bg='blue')
btn3.grid(row=1,column=0)
btn4 = tk.Button(window,text='four',width=15,height=10,bg='yellow')
btn4.grid(row=1,column=1)
window.mainloop()
效果如图:
咦,绿色按钮怎么不见了?
要注意,这里的合并单元格和html中<table>标签的合并单元格不同,合并单元格后,其他单元格中的控件并不会自动被挤开,因此实际上,此时绿色按钮被黄色的按钮遮挡住了,可以试着增大绿色按钮的宽高就能知道它的位置了。
既然合并单元格周围的控件不会自动被挤开,那我们就只能手动更改其坐标了。
为了便于理解,我们看张示意图:
从图中可以看出,应该将红色按钮坐标设为(0,2),蓝色按钮坐标设为(2,0),黄色按钮坐标设为(2,1)(准确地说应该是设置行和列的序号)。
改动后代码如下:
#文件名:test.py
import tkinter as tk
window = tk.Tk()
window.title('test')
window.geometry('400x400')
btn1 = tk.Button(window,text='one',width=5,bg='green')
btn1.grid(row=0,column=0,rowspan=2,columnspan=2)
btn2 = tk.Button(window,text='two',width=5,height=5,bg='red')
btn2.grid(row=0,column=2)
btn3 = tk.Button(window,text='three',width=3,height=3,bg='blue')
btn3.grid(row=2,column=0)
btn4 = tk.Button(window,text='four',width=15,height=10,bg='yellow')
btn4.grid(row=2,column=1)
window.mainloop()
效果如图:
你可能会觉得,绿色按钮并没有在竖直方向上占用两个两行单元格,前面说过,单元格的高度是由一行中最高的控件的高度决定的,而第二行中没有控件,是空的,所以高度为0。
我们在第二行添加一个灰色按钮,这样可以更清楚地看出各个按钮的位置关系:
#文件名:test.py
import tkinter as tk
window = tk.Tk()
window.title('test')
window.geometry('400x400')
btn1 = tk.Button(window,text='one',width=5,bg='green')
btn1.grid(row=0,column=0,rowspan=2,columnspan=2)
btn2 = tk.Button(window,text='two',width=5,height=5,bg='red')
btn2.grid(row=0,column=2)
btn3 = tk.Button(window,text='three',width=3,height=3,bg='blue')
btn3.grid(row=2,column=0)
btn4 = tk.Button(window,text='four',width=15,height=10,bg='yellow')
btn4.grid(row=2,column=1)
btn5 = tk.Button(window,text='five',width=15,height=4,bg='gray')
btn5.grid(row=1,column=2)
window.mainloop()
效果如图:
4,sticky
sticky属性用于设置控件的对齐方式,其可选值有'N'、'S'、'E'、'W'以及这四个值的各种组合。
当stick属性的值为这四个方向中的一个时,控件会向相应方向对齐;当stick属性的值为其中两个时,控件会向相应的一个角对齐;当stick属性的值为其中三个、四个时,控件会先向前两个设定的方向对齐,然后向后两个方向进行填充。
例如,我们将绿色按钮设为sticky='W'时,则它会左对齐,如图所示:
当我们将绿色按钮设为sticky='W'+'N'时,则它会左对齐+顶对齐,因此会位于单元格的左上角,如图所示:
当我们将绿色按钮设为sticky='W'+'N'+'S'时,则它会先进行左对齐+顶对齐,然后向下填充单元格,如图所示:
当我们将绿色按钮设为sticky='W'+'N'+'S'+'E'时,则它会先进行左对齐+顶对齐,然后向下、向右填充单元格,如图所示:
三、place()
place()有以下几个常用属性:
- x
- y
- relx
- rely
- anchor
1,x、y
x、y属性用来设置控件的绝对坐标。
2,relx、rely
relx、rely属性用来设置控件的相对坐标,范围为0-1。
可以同时使用相对坐标和绝对坐标,此时先根据相对坐标确定控件位置,然后根据绝对坐标使控件进行偏移,最后确定控件的最终位置。
3,anchor
anchor属性有9个可选值,分别表示9个方向,用来设置控件的锚点。如图所示:
例如,anchor='nw',x=100,y=100表示控件的左上角将在坐标(100,100)处,而anchor='n',x=100,y=100表示控件的顶边中点将在坐标(100,100)处。
四、Frame()
Frame()本身是tkinter中的一类控件,用来帮助我们进行布局。
首先我们创建四个框架,同时创建一个标签,为了方便观察,我们给框架添加了背景色和边框,如下所示:
#文件名:test'.py
import tkinter as tk
window = tk.Tk()
window.title('test window')
window.geometry('400x400')
f1 = tk.Frame(window,width=150,height=150,bg='blue',borderwidth=2)
f2 = tk.Frame(window,width=150,height=150,bg='red',borderwidth=2)
f3 = tk.Frame(window,width=150,height=150,bg='gray',borderwidth=2)
f4 = tk.Frame(window,width=150,height=150,bg='yellow',borderwidth=2)
f1.grid(row=0, column=0)
f2.grid(row=0, column=1)
f3.grid(row=1, column=0)
f4.grid(row=1, column=1)
l1 = tk.Label(window,text='one',bg='pink',width=5).grid(row=0,column=0)
window.mainloop()
效果如图:
此时的框架似乎就是一个普通的矩形控件。
接着我们将标签放入框架中,也即将框架作为标签的父对象(为了避免大段大段的重复代码影响阅读,我们使用----snip----表示省略部分前文已使用过的重复代码。):
#文件名:test'.py
import tkinter as tk
----snip----
l1 = tk.Label(f1,text='one',bg='pink',width=5).grid(row=0,column=0)
----snip----
window.mainloop()
效果如图:
可以发现,框架的大小发生了改变,准确地说,框架大小变为了框架中控件的大小。
接着,我们再添加一个标签:
#文件名:test'.py
import tkinter as tk
----snip----
l1 = tk.Label(f1,text='one',bg='pink',width=5).grid(row=0,column=0)
l2 = tk.Label(f1,text='two',bg='pink',width=5).grid(row=1,column=1)
----snip----
window.mainloop()
效果如图:
此时,框架的大小是框架中所有控件的外接矩形的大小,也即刚好将所有控件包裹住的大小。
如果想改变框架的位置,比如使其在左上角,只需设置sticky='W'+'N'即可。
另外再来看一种情况,我们将标签的宽度增大:
#文件名:test'.py
import tkinter as tk
----snip----
l1 = tk.Label(f1,text='one',bg='pink',width=15).grid(row=0,column=0)
l2 = tk.Label(f1,text='two',bg='pink',width=15).grid(row=1,column=1)
----snip----
window.mainloop()
效果如图:
框架被里面的控件撑起来了!
python tkinter学习——布局的更多相关文章
- Python Tkinter 学习成果:点歌软件music
笔者工作业余时间也没什么爱好,社交圈子也小,主要娱乐就是背着自己带电瓶的卖唱音响到住地附近找个人多的位置唱唱KtV. 硬件上点歌就用笔记本电脑,歌曲都是网上下载的mkv格式的含有两个音轨的视频.因此点 ...
- Python Tkinter学习笔记
介绍 入门实例 显示一个窗口,窗口里面有一个标签,显示文字 import tkinter as tk # 一个顶层窗口的实例(Top Level),也称为根窗口 app = tk.Tk() # 设置窗 ...
- Python Tkinter学习(1)——第一个Tkinter程序
注:本文可转载,转载请注明出处:http://www.cnblogs.com/collectionne/p/6885066.html.格式修改未完成. Tkinter资料 Python Wiki, T ...
- Python Tkinter 学习历程 一
一丶一个简单的程序 from tkinter import * #引入所有类#查看tk版本#tkinter._test() root = Tk(); #对这个类进行实例化 w1 = Label(roo ...
- tkinter学习-布局管理器
阅读目录 pack 是按照添加顺序排列的组件 grid 是按照行/列形式排序的组件 place 允许程序员指定组件的大小和位置 pack: 说明:适用于少量的简单的组件的排列 fill:这个选项是告 ...
- Python Tkinter Grid布局管理器详解
Grid(网格)布局管理器会将控件放置到一个二维的表格里.主控件被分割成一系列的行和列,表格中的每个单元(cell)都可以放置一个控件. 注意:不要试图在一个主窗口中混合使用pack和grid (1) ...
- Python tkinter 学习记录(一) --label 与 button
最简的形式 from tkinter import * root = Tk() # 创建一个Tk实例 root.wm_title("标题") # 修改标题 root.mainloo ...
- python+tkinter 的布局
from tkinter import * win = Tk() win.title("布局") # #窗口标题 win.geometry("600x500+200+20 ...
- python tkinter学习——tkinter部件1
tkinter部件 一.Tk() & Label() & Button() 1,Tk() 窗口 用Tk()创建窗口对象: #文件名:test1.py import tkinter as ...
随机推荐
- NPOI 2.1.1 系列(1) 使用NPOI读取 Excel文档 ;NpoiExcelHelper 导入导出 2003格式 2007格式的 Excel; Npoi 导出 xlsx 格式
下载地址 http://npoi.codeplex.com/releases 下面放一个 NPOIHelper 助手类吧,也不是我写的- NpoiExcelHelper 可以生成xlsx格式publi ...
- Oracle触发器给表自身的字段重新赋值出现ORA-04091异常
业务描述如下: 在插入一个表的时候,需要根据一个字段的值更新另一个字段的值.当然也可以通过程序就能很简单得实现,只是这个字段只是数据交换用,和系统主业务没关系,不想修改程序,所以才用触发器的方式实现. ...
- 面向切面编程(AOP)简介
在软件中,有些行为对于大多数应用都是通用的.日志,安全和事务管理几乎是所有软件都需要的.他们是否可以主动的参与呢,如果让应用程序只关注与自己所针对的业务领域问题,而其他的问题有其他应用对象来处理.是否 ...
- CodeFirst时使用T4模板
我们都知道T4模板用于生成相似代码. 在DBFirst和ModelFirst条件下我们很容易从.edmx下获取所有实体类和其名称,并且通过我们定义的模板和某些遍历工作为我们生成所需要的相似代码. 但是 ...
- #AOS应用基础平台# 实现了在用户权限范围内自己定义的快捷菜单的导航展示
from=501" style="color:rgb(255,131,115); padding:0px; margin:0px; font-family:微软雅黑,Verdana ...
- Android中利用C++处理Bitmap对象
相信有些Android&图像算法开发者和我一样,遇到过这样的状况:要对Bitmap对象做一些密集计算(例如逐像素的滤波),但是在java层写循环代码来逐像素操作明显是不现实的,因为Java代码 ...
- curl tutorial with examples of usage
原文:http://www.yilmazhuseyin.com/blog/dev/curl-tutorial-examples-usage/ 阮一峰的这个教程也不错:http://www.ruanyi ...
- 【Spark】session 代替 SparkConf、SparkContext和SQLContext
http://www.raincent.com/content-85-7196-1.html
- 关于High-Contrast的资料
SystemParameters.HighContrast Propertyhttp://msdn.microsoft.com/en-us/library/system.windows.systemp ...
- flashfxp v3.7 注册码
-------- FlashFXP Registration Data START --------FLASHFXPvwBW1S4QvwAAAAC5W5MNJwXnsl73i3CxcVAAvAyagF ...