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下载Bing图片(代码)
Nov 07 Python
Python实现拼接多张图片的方法
Dec 01 Python
Python实现竖排打印传单手机号码易撕条
Mar 16 Python
在Python web中实现验证码图片代码分享
Nov 09 Python
python如何统计序列中元素
Jul 31 Python
使用python读取csv文件快速插入数据库的实例
Jun 21 Python
使用pandas read_table读取csv文件的方法
Jul 04 Python
对django views中 request, response的常用操作详解
Jul 17 Python
Python+OpenCV实现将图像转换为二进制格式
Jan 09 Python
Python多线程操作之互斥锁、递归锁、信号量、事件实例详解
Mar 24 Python
Python爬虫自动化获取华图和粉笔网站的错题(推荐)
Jan 08 Python
PyQt5通过信号实现MVC的示例
Feb 06 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
必须收藏的23个php实用代码片段
2016/02/02 PHP
Laravel框架实现多个视图共享相同数据的方法详解
2019/07/09 PHP
解决js中window.open弹出的是上次的缓存页面问题
2013/12/29 Javascript
SeaJS入门教程系列之SeaJS介绍(一)
2014/03/03 Javascript
JS倒计时代码汇总
2014/11/25 Javascript
jquery实现叠层3D文字特效代码分享
2015/08/21 Javascript
详解AngularJS中module模块的导入导出
2015/12/10 Javascript
简单的JS时钟实例讲解
2016/01/13 Javascript
javascript实现tab响应式切换特效
2016/01/29 Javascript
jQuery实现的纵向下拉菜单实例详解【附demo源码下载】
2016/07/09 Javascript
Node.js如何自动审核团队的代码
2016/07/20 Javascript
又一款MVVM组件 构建自己的Vue组件(2)
2017/03/13 Javascript
基于iScroll实现内容滚动效果
2018/03/21 Javascript
vue如何判断dom的class
2018/04/26 Javascript
微信小程序实现自定义modal弹窗封装的方法
2018/06/15 Javascript
ng-repeat指令在迭代对象时的去重方法
2018/10/02 Javascript
微信小程序学习笔记之获取位置信息操作图文详解
2019/03/29 Javascript
Openlayers实现地图的基本操作
2020/09/28 Javascript
python利用paramiko连接远程服务器执行命令的方法
2017/10/16 Python
python生成excel的实例代码
2017/11/08 Python
python getpass实现密文实例详解
2019/09/24 Python
Python 实现将数组/矩阵转换成Image类
2020/01/09 Python
Python+Kepler.gl实现时间轮播地图过程解析
2020/07/20 Python
爬虫代理的cookie如何生成运行
2020/09/22 Python
美国新兴城市生活方式零售商:VILLA
2017/12/06 全球购物
党章学习思想汇报
2014/01/14 职场文书
秋季运动会通讯稿
2014/01/24 职场文书
中学学校门卫岗位职责
2014/08/15 职场文书
优秀教师自我评价范文
2014/09/27 职场文书
公司员工离职证明书
2014/10/04 职场文书
个人授权委托书范本格式
2014/10/12 职场文书
迟到检讨书
2015/01/26 职场文书
实习介绍信模板
2015/01/30 职场文书
签字仪式主持词
2015/07/03 职场文书
AJAX学习笔记
2021/05/18 Javascript
解决springboot druid数据库连接失败后一直重连的方法
2022/04/19 Java/Android