用Tkinter打造GUI开发工具(29)可视化设计之Pack布局及生成代码

117 篇文章 122 订阅
115 篇文章 108 订阅

用Tkinter打造GUI开发工具(29)可视化设计之Pack布局及生成代码

前面我们介绍了Tkinter的2个布局方法的可视化设计,这2个方法是Place和Grid布局。这篇介绍Pack布局的可视化设计程。
我们仍然要依赖HP_tk2来实现设个设计程序。

# Tkinter GUI可视化生成代码验证程序.
import tkinter as tk
import tkinter as ttk
import tkinter.tix as tix 
from tkinter.constants import *
import PIL
import random
import time
import HP_tk2 as htk
import HP_global as g 
if __name__ == '__main__':
    root = tix.Tk()   #主窗口root
    root.title("可视化设计Pack")
    f0=tk.Toplevel(root)  #可视化子窗
    f0.title('Pack布局设计')  #Tkinter中设置窗口标题方法
    top=htk.resizewidget(f0,400,400)  #建立可调部件区域
    f1=tk.Frame(top)
    f1.place(x=0, y=0,  #坐标起点(0,0)
                    width=300, #部件相对于窗口的宽度
                    height=300, #部件相对于窗口的高度
                    bordermode=tk.OUTSIDE  #部件边框模式
                    )  #使用place方法的相对位置
    top.setwidget(f1)  #加入可调部件
#下面放4个按钮控件,调整位置。
    pck=htk.packwidget(f1)
    b1=tk.Button(pck,text='控件1')
    pck.setwidget(b1)

    b2=tk.Button(pck,text='控件2')
    pck.setwidget(b2)

    b3=tk.Button(pck,text='控件3')
    pck.setwidget(b3)

    b4=tk.Button(pck,text='控件4')
    pck.setwidget(b4)
    
    def btn_cmd():
        pck.get_anchor()

    def btn_cmd2():
        pck.get_side()

    def btn_cmd3():
        pck.get_fill()

    def btn_cmd4():
        py=pck.to_py() 
        print(py)
      
    btn=tk.Button(root,text='设置anchor工具',command=btn_cmd)
    btn.place(x=10,y=10)

    btn3=tk.Button(root,text='设置side工具',command=btn_cmd2)
    btn3.place(x=10,y=50)

    btn4=tk.Button(root,text='设置fill工具',command=btn_cmd3)
    btn4.place(x=10,y=90)    
    
    btn5=tk.Button(root,text='生成代码',command=btn_cmd4)
    btn5.place(x=10,y=130)  
    root.mainloop()

程序运行结果如下图。
在这里插入图片描述
我们打开布局调整工具,对布局进行设计,最终设计布局如下图。
在这里插入图片描述
点按钮[生成代码],获得如下程序。

import tkinter as tk
import tkinter as ttk
import tkinter.tix as tix 
from tkinter.constants import *

root = tix.Tk()   #主窗口root
root.title("可视化设计结果")
root.geometry('{}x{}'.format(300,300))  #改变窗口大小

f0=tk.Button(root,text='label0',command=None)
f0.pack(anchor='n',side='top',fill='x',expand=0)
f1=tk.Button(root,text='label1',command=None)
f1.pack(anchor='n',side='left',fill='y',expand=0)
f2=tk.Button(root,text='label2',command=None)
f2.pack(anchor='n',side='bottom',fill='x',expand=0)
f3=tk.Button(root,text='label3',command=None)
f3.pack(anchor='n',side='right',fill='both',expand=1)
root.mainloop()

这个程序运行,产生下面图形。
在这里插入图片描述
程序执行结果与可视化设计的图形一致。
这篇我们介绍了Tkinter的Pack布局可视化及生成代码的过程。至此我们完成了Place布局、Grid布局、Pack布局的可视化设计。
Tkinter还有一个Form布局,这个布局可视化设计完成,我们用Tkinter进行可视化Tkinter的GUI程序的设计技术就全部具备。后面就可以在此基础上用Tkinter做一个Python的可视化程序开发工具。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

荷蒲

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值