Tkinter布局方式【三】

在Tkinter中,提供了三种布局方式。pack(打包)、grid(网格布局)、place(定位布局)。

布局方法说明
pack()按照组件添加到容器的顺序布局。在使用容器(Frame)布局时非常方便,调整窗口大小时布局自动缩放
grid()网格布局,以行、列来对组件进行布局,较为灵活
place()定位布局,指定组件大小和位置,最灵活

pack()

打包器,将组件打包进父组件中。

常用参数说明
anchor指定组件方向,取值 NSEW,北南东西,和他们的组合方位,以及Center
expand如果父组件的大小增加,则展开当前组件
fill是否拉伸组件 NONE(不拉伸) 、X(横向拉伸)、Y(竖向拉伸)、BOTH(都拉伸)
side将组件添加到哪 TOP、 BOTTOM 、 LEFT 、 RIGHT

{{< expand “pack()布局例子” >}}

# 导入tkinter
from tkinter import *
# 导入ttk
from tkinter.ttk import *

# 创建一个窗口
win = Tk()
# 设置标题
win.title("布局器 pack() 演示 ~ Tkinter布局助手")
# 窗口大小设置
win.geometry("500x200")
# 创建一个文本标签
top = Label(win, background="red")
left = Label(win, background="blue")

# 调整这里的顺序试试
left.pack(side=LEFT, fill=BOTH)
top.pack(side=TOP, fill=BOTH)

# 展示窗口
win.mainloop()

{{< /expand >}}

pack的布局跟添加的顺序有关,注意下面图的红色和蓝色相交位置,体会其中差别。

先添加left后添加top

先添加top后添加left

grid()

网格布局,用类似网格的形式,将界面分为几行,几列,每个组件布置在相应的格子里。

常用参数说明
column组件在第几列 默认从0开始
columnspan这个组件跨了几个列
row组件在第几行 默认从0开始
rowspan这个组件跨了几行
sticky组件在单元格内,靠近哪边,默认居中

{{< expand “grid()布局例子” >}}

# 导入tkinter
from tkinter import *
# 导入ttk
from tkinter.ttk import *

# 创建一个窗口
win = Tk()
# 设置标题
win.title("布局器 grid() 演示 ~ Tkinter布局助手")
# 窗口大小设置
win.geometry("500x200")

for i in range(1, 4):
    for j in range(1, 4):
        btn = Button(win, text=str(i * j))
        btn.grid(column=i, row=j)
# 展示窗口
win.mainloop()

{{< /expand >}}

grid布局

place()

三种中最灵活的一种,可以指定大小和绝对位置布局,也可以相对父组件的大小、相对位置布局。
Tkinter布局助手就是基于place()的布局方式实现的。

常用参数说明
width组件的宽度 默认单位像素
height组件高度 默认单位像素
x相对父组件的x轴位置 (距顶部的距离) 默认单位像素
y相对父组件的y轴位置 (距左边的距离) 默认单位像素
relwidth组件的宽度 相对于父组件的宽度,取值0-1 为1时与父组件宽度一致
relheight组件的高度 相对于父组件的高度,取值0-1 为1时与父组件高度一致
relx相对父组件的x轴位置 (距顶部的距离) 取值0-1 为1时与父组件宽度一致
rely相对父组件的y轴位置 (距左边边的距离) 取值0-1 为1时与父组件高度一致

{{< expand “grid()布局例子” >}}

# 导入tkinter
from tkinter import *
# 导入ttk
from tkinter.ttk import *

# 创建一个窗口
win = Tk()
# 设置标题
win.title("布局器 place() 演示 ~ Tkinter布局助手")
# 窗口大小设置
win.geometry("500x200")

btn = Button(win, text="相对大小 大小位置可随窗口大小变化")
btn.place(relheight=0.2, relwidth=0.5, relx=0.2, rely=0.3)

btn2 = Button(win, text="按钮")
btn2.place(height=50, width=80, x=10, y=20)

# 展示窗口
win.mainloop()

{{< /expand >}}

place布局

调整大小后,图中的小按钮大小和位置没有变化,设置相对大小的按钮大小发生了变化。

拉伸后

  • 22
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
这是一个VB6的IDE插件(Addin),使用VB6的IDE直接设计Python的界面。 Python和VB都是能让人快乐的编程语言,我使用了Python之后,很多自己使用的工具都使用Python开发或改写了,因为最终实现的Python代码实在太短了(相比VB),有时候Python一行代码就可以实现VB一个函数的功能。 Python就是这种让人越用越开心的语言。 不过说实在,使用Python开发GUI界面还是麻烦了一些了,自带的标准库Tkinter使用起来非常简单,不过对于习惯了VB拖放控件完成界面设计的偶来说,还是不够人性化。TK也有一个工具叫GUI Builder,不过它使用Layout布局,不够直观,而且用起来很不爽。。 至于PyQt/wxPython等GUI库,尽管有可视化设计工具,但总感觉做一般的轻量级应用是杀鸡用牛刀, 而且不够环保,不够低碳,要带一个很大的库,需要目标机器上夜同样安装了PyQt/wxPython,做不了绿色软件。 所以最终的结果是我更喜欢Tkinter,用起来很简单,绿色环保,真正的跨平台,一个py文件到处运行(担心泄密就编译成pyc)。 很多人都认为TK的界面不够美观,不过我经过多次实验后发现导入Python自带的标准TTK主题库,界面非常Native,不输PyQt/wxPython。 此Addin默认启用TTK支持,也可选择关闭。 总而言之,轻量级GUI,TK+TTK足够。 使用此Addin,你可以不用写一句代码就可以生成一个完整可运行的Python的GUI界面,支持2.X和3.X。 安装方法:将压缩包解压到你希望的目录,然后执行Setup.exe完成注册插件过程,打开VB6就可以用了。 在VB窗体上设计完成界面后(你可以大胆的设置各控件的属性,Addin尽量将其翻译为tkinter的控件属性),点工具栏上的VisualTkinter(图标为一片羽毛),再点'生成代码'按钮,即可生成可运行的Python代码,可以拷贝至剪贴板或保存至文件。 一般情况下你可以不用再改变tkinter的控件属性,但是如果你熟悉tkinter,需要更多的控制,可以一一核对各属性,并且修改,再生成代码。 当然除了用来设计界面外,此ADDIN内置的各控件属性列表可以做为编程参考,比较完整,除了极少数我认为大多数人都不用的属性外,属性定义基本上是我从官方的tkinter文档直接翻译的。 如果还没有VB6,网上找一个VB6精简版即可,不到20M,小巧玲珑。 代码已经在Github上托管,更新的版本可以在这上面找到,需求也可以在上面提: https://github.com/cdhigh/Visual-Tkinter-for-Python

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值