python图形开发GUI库wxpython使用方法详解


Posted in Python onFebruary 14, 2020

一、python gui(图形化)模块介绍:

Tkinter :是python最简单的图形化模块,总共只有14种组建

Pyqt     :是python最复杂也是使用最广泛的图形化

Wx       :是python当中居中的一个图形化,学习结构很清晰

Pywin   :是python windows 下的模块,摄像头控制(opencv),常用于外挂制作

二、wx模块的安装:

C:\Users\Administrator> pip install wxpython

三、图形化介绍

python图形开发GUI库wxpython使用方法详解

 python图形开发GUI库wxpython使用方法详解

四、wx主要组件介绍

1、frame(窗口)

参数:

parent = None #父元素,假如为None,代表顶级窗口

id = None #组件的标识,唯一,假如id为-1代表系统分配id

title = None #窗口组件的名称

pos = None #组件的位置,就是组件左上角点距离父组件或者桌面左和上的距离

size = None #组件的尺寸,宽高

style = None #组件的样式

name = None #组件的名称,也是用来标识组件的,但是用于传值

2、TextCtrl(文本框)

参数:

parent = None #父元素,假如为None,代表顶级窗口

id = None #组件的标识,唯一,假如id为-1代表系统分配id

value = None   #文本框当中的内容

         GetValue #获取文本框的值

         SetValue #设置文本框的值

pos = None #组件的位置,就是组件左上角点距离父组件或者桌面左和上的距离

size = None #组件的尺寸,宽高

style = None #组件的样式

validator = None #验证

name = None #组件的名称,也是用来标识组件的,但是用于传值

3、Button(按钮)

参数:

parent = None #父元素,假如为None,代表顶级窗口

id = None #组件的标识,唯一,假如id为-1代表系统分配id

lable = None #按钮的标签

pos = None #组件的位置,就是组件左上角点距离父组件或者桌面左和上的距离

size = None #组件的尺寸,宽高

style = None #组件的样式

validator = None #验证

name = None #组件的名称,也是用来标识组件的,但是用于传值

其它组件的参数类似

4、创建窗口基础代码

基本创建窗口代码说明:

import wx #引入wx模块
app = wx.App() #实例化一个主循环<br>
frame = wx.Frame(None) #实例化一个窗口<br>
frame.Show()#调用窗口展示功能<br>
app.MainLoop()#启动主循环

效果如下图:

python图形开发GUI库wxpython使用方法详解

五、Gui编写简单实例

实现如下一个GUI界面,在上面文本框中输入文本文件地址,点击“打开”按钮后将文本文件内容显示在下面的文本框中。

python图形开发GUI库wxpython使用方法详解

1、图形化编写

import wx
 
app = wx.App()
frame = wx.Frame(None,title = "Gui Test Editor",pos = (1000,200),size = (500,400))
 
path_text = wx.TextCtrl(frame,pos = (5,5),size = (350,24))
open_button = wx.Button(frame,label = "打开",pos = (370,5),size = (50,24))
save_button = wx.Button(frame,label = "保存",pos = (430,5),size = (50,24))
content_text= wx.TextCtrl(frame,pos = (5,39),size = (475,300),style = wx.TE_MULTILINE) # wx.TE_MULTILINE可以实现换行功能,若不加此功能文本文档显示为一行显示
frame.Show() app.MainLoop()

2、事件绑定

1、定义事件函数

事件函数有且只有一个参数,叫event

def openfile(event):
  path = path_text.GetValue()
  with open(path,"r",encoding="utf-8") as f: #encoding 设置文件打开时指定为utf8编码,避免写文件时出现编码错误
    content_text.SetValue(f.read())

2、绑定出发事件的条件和组件

open_button.Bind(wx.EVT_BUTTON,openfile)

3、完整代码

#coding:utf-8
import wx
 
def openfile(event):   # 定义打开文件事件
  path = path_text.GetValue()
  with open(path,"r",encoding="utf-8") as f: # encoding参数是为了在打开文件时将编码转为utf8
    content_text.SetValue(f.read())
 
app = wx.App()
frame = wx.Frame(None,title = "Gui Test Editor",pos = (1000,200),size = (500,400))
 
path_text = wx.TextCtrl(frame,pos = (5,5),size = (350,24))
open_button = wx.Button(frame,label = "打开",pos = (370,5),size = (50,24))
open_button.Bind(wx.EVT_BUTTON,openfile)  # 绑定打开文件事件到open_button按钮上
 
save_button = wx.Button(frame,label = "保存",pos = (430,5),size = (50,24))
 
content_text= wx.TextCtrl(frame,pos = (5,39),size = (475,300),style = wx.TE_MULTILINE)
# wx.TE_MULTILINE可以实现以滚动条方式多行显示文本,若不加此功能文本文档显示为一行
 
frame.Show()
app.MainLoop()

python图形开发GUI库wxpython使用方法详解

六、尺寸器

按照上面的GUI代码有一个缺陷,由于我们各个组件都固定了大小,因此在框体拉伸时,对应的组件不会对应进行拉伸,比较影响用户体验。

python图形开发GUI库wxpython使用方法详解

为了解决上述这个问题,我们可以使用尺寸器进行布局,类似于HTML的CSS样式。

1、BoxSizer(尺寸器)

  • 尺寸器作用于画布(panel)
  • 默认水平布局
  • 垂直布局可以调整
  • 按照相对比例

2、步骤

  • 实例化尺寸器(可以是多个)
  • 添加组件到不同尺寸器中
  • 设置相对比例、填充的样式和方向、边框等参数
  • 设置主尺寸器

3、将上面代码通过尺寸器改写

python图形开发GUI库wxpython使用方法详解

#coding:utf-8
import wx
 
def openfile(event):   # 定义打开文件事件
  path = path_text.GetValue()
  with open(path,"r",encoding="utf-8") as f: # encoding参数是为了在打开文件时将编码转为utf8
    content_text.SetValue(f.read())
 
app = wx.App()
frame = wx.Frame(None,title = "Gui Test Editor",pos = (1000,200),size = (500,400))
 
panel = wx.Panel(frame)
 
path_text = wx.TextCtrl(panel)
open_button = wx.Button(panel,label = "打开")
open_button.Bind(wx.EVT_BUTTON,openfile)  # 绑定打开文件事件到open_button按钮上
 
save_button = wx.Button(panel,label = "保存")
 
content_text= wx.TextCtrl(panel,style = wx.TE_MULTILINE)
# wx.TE_MULTILINE可以实现以滚动条方式多行显示文本,若不加此功能文本文档显示为一行
 
box = wx.BoxSizer() # 不带参数表示默认实例化一个水平尺寸器
box.Add(path_text,proportion = 5,flag = wx.EXPAND|wx.ALL,border = 3) # 添加组件
  #proportion:相对比例
  #flag:填充的样式和方向,wx.EXPAND为完整填充,wx.ALL为填充的方向
  #border:边框
box.Add(open_button,proportion = 2,flag = wx.EXPAND|wx.ALL,border = 3) # 添加组件
box.Add(save_button,proportion = 2,flag = wx.EXPAND|wx.ALL,border = 3) # 添加组件
 
v_box = wx.BoxSizer(wx.VERTICAL) # wx.VERTICAL参数表示实例化一个垂直尺寸器
v_box.Add(box,proportion = 1,flag = wx.EXPAND|wx.ALL,border = 3) # 添加组件
v_box.Add(content_text,proportion = 5,flag = wx.EXPAND|wx.ALL,border = 3) # 添加组件
 
panel.SetSizer(v_box) # 设置主尺寸器
 
frame.Show()
app.MainLoop()

通过尺寸器进行布局,无论宽体如何拉伸,内部的组件都会按比例进行变化。

python图形开发GUI库wxpython使用方法详解

python图形开发GUI库wxpython使用方法详解

更多关于python图形开发GUI库wxpython使用方法请查看下面的相关链接

Python 相关文章推荐
Python Mysql自动备份脚本
Jul 14 Python
浅谈Python 对象内存占用
Jul 15 Python
python 3.5实现检测路由器流量并写入txt的方法实例
Dec 17 Python
Python+Turtle动态绘制一棵树实例分享
Jan 16 Python
python中subprocess批量执行linux命令
Apr 27 Python
python中文编码与json中文输出问题详解
Aug 24 Python
Python实现数据结构线性链表(单链表)算法示例
May 04 Python
解决Django加载静态资源失败的问题
Jul 28 Python
PyCharm下载和安装详细步骤
Dec 17 Python
Python使用正则实现计算字符串算式
Dec 29 Python
PyQt实现计数器的方法示例
Jan 18 Python
使用Python脚本对GiteePages进行一键部署的使用说明
May 27 Python
解决Pycharm中恢复被exclude的项目问题(pycharm source root)
Feb 14 #Python
Python requests模块基础使用方法实例及高级应用(自动登陆,抓取网页源码)实例详解
Feb 14 #Python
Python实现名片管理系统
Feb 14 #Python
pycharm设置当前工作目录的操作(working directory)
Feb 14 #Python
python设置代理和添加镜像源的方法
Feb 14 #Python
pycharm 中mark directory as exclude的用法详解
Feb 14 #Python
Python读取分割压缩TXT文本文件实例
Feb 14 #Python
You might like
php中目录,文件操作详谈
2007/03/19 PHP
php 缓存函数代码
2008/08/27 PHP
return false;和e.preventDefault();的区别
2010/07/11 Javascript
使用JS进行目录上传(相当于批量上传)
2010/12/05 Javascript
JS打开新窗口的2种方式
2013/04/18 Javascript
判断在css加载完毕后执行后续代码示例
2014/09/03 Javascript
基于jQuery的JavaScript模版引擎JsRender使用指南
2014/12/29 Javascript
jQuery实现的类似淘宝网站搜索框样式代码分享
2015/08/24 Javascript
js实现超简单的展开、折叠目录代码
2015/08/28 Javascript
使用Javascript写的2048小游戏
2015/11/25 Javascript
jQuery实现左侧导航模块的显示与隐藏效果
2016/07/04 Javascript
js+html制作简单验证码
2017/02/16 Javascript
Vue服务端渲染和Vue浏览器端渲染的性能对比(实例PK )
2017/03/31 Javascript
使用vue制作FullPage页面滚动效果
2017/08/21 Javascript
js + css实现标签内容切换功能(实例讲解)
2017/10/09 Javascript
vue iview组件表格 render函数的使用方法详解
2018/03/15 Javascript
JavaScript 中的六种循环方法
2021/01/06 Javascript
Python监控主机是否存活并以邮件报警
2015/09/22 Python
利用python爬取软考试题之ip自动代理
2017/03/28 Python
基于python requests库中的代理实例讲解
2018/05/07 Python
Python使用Phantomjs截屏网页的方法
2018/05/17 Python
Python中psutil的介绍与用法
2019/05/02 Python
python KNN算法实现鸢尾花数据集分类
2019/10/24 Python
python属于解释型语言么
2020/06/15 Python
html5 Canvas实现图片旋转的示例
2018/01/15 HTML / CSS
以太网Ethernet IEEE802.3
2013/08/05 面试题
单位单身证明范本
2014/01/11 职场文书
互联网创业计划书写作技巧攻略
2014/03/23 职场文书
酒店管理求职信范文
2014/04/06 职场文书
《第一朵杏花》教学反思
2014/04/16 职场文书
补充协议书范本
2014/04/23 职场文书
学校教研活动总结
2014/07/02 职场文书
机电一体化应届生求职信
2014/08/09 职场文书
大学生翘课检讨书范文
2014/10/06 职场文书
关于空气污染危害的感想
2015/08/11 职场文书
银行求职信怎么写
2019/06/20 职场文书