PyQt5 GUI应用程序工具包入门(2)
下面我们从一个简单的登录对话框来了解PyQt5的开发过程。 PyQt5支持两种界面开发方式:一种是在QtDesigner中设计界面,各种控件直接通过拖动添加;一另种是直接撰写界面代码,通过代码控制界面上的控件。下面我们将分别通过这两种方式建立一个如图1所示的登陆对话框。
图1 一个简单的登陆对话框
QtDesigner设计界面
经过上一篇文章的设置后,我们可通过菜单栏的“Tool”→“QT Tool”→“Qt Designer”打开QtDesigner程序,进行界面设计,如图2。
图2 QtDesinger界面
由于我们只需建立一个简单的窗口,故选择模板为“Widget”,单击“创建”,即进入窗口编辑界面,如图3所示。
图3 新建窗口
我们只需将所需的控件拖入即可,这里我们需要2个Push Button(Buttons中),2个Label(Display Widget中)和2个Line Edit(Import Widgets中)。拖入后大致安排好位置(如图4)。
图4 窗口初步设计
在窗口空白处单击鼠标右键,选择“布局”→“栅格布局”,即可将控件大致排列好。
然后,在对象查看器中单击对象,即可在属性编辑对话框设置控件属性。这个项目中我们进行如下设置:
- 设置Form的“WindowTitle”为“登录界面”,
- 设置两个Label的“text”分别为“用户名”和“密码”,
- 设置两个按钮的“text”分别为确定和取消。 设置完后将窗口调到适当大小(图5)。
图5 最终窗口
最后,将本窗口以ui文件保存在项目文件夹,选择此文件,单击鼠标右键,选择“QT Tool”→“PyUIC”,即可生成py文件。
直接撰写界面代码
在上一节生成的ui文件是需要转换成py文件来使用的。故,我们也可以直接撰写界面代码,来进行开发。 代码如下:
# -*- coding: utf-8 -*-
from PyQt5.QtWidgets import *
class Ui_Form(QWidget):
def __init__(self):
super().__init__()
self.setWindowTitle("登录界面")
self.resize(200,100)
lay=QFormLayout()
self.setLayout(lay)
Lab1=QLabel("用户名")
Line1=QLineEdit()
Lab2 = QLabel("密码")
Line2 = QLineEdit()
OkB=QPushButton("确定")
CB=QPushButton("取消")
lay.addRow(Lab1,Line1)
lay.addRow(Lab2, Line2)
lay.addRow(OkB,CB)
代码说明:
- 第2行,导入PyQt5的控件,PyQt5的各种控件一般均放在PyQt5.QtWidgets模块中,本行代码导入了所有的控件,也可只导入本程序用到的控件,即写作“from PyQt5.QtWidgets import QWidget,QFormLayout,QLabel,QLineEdit,QPushButton”,熟知Python语法的人可能有其他写法,本篇不再赘述;
- 第4行,建立Ui_Form类,从QWidget基类派生;
- 第5、6行,构造函数,完整写法为:
- def init(self,parent=None): super(Ui_form,self).init(parent) 而在Python3中可以简化为第5、6行的形式;
- 第7行,设置窗口名称;
- 第8行,设置窗口尺寸;
- 第9、10行,设置总体布局;
- 第12~19行,建立控件对象;
- 第21~3行,将控件加入布局中。
运行程序
以上生成的窗口类可以在同一个py文件中书写main函数进行调用。不过笔者不建议这样做。尤其是第一种方法中需要修改窗口时,同时也要重新生成py文件,还需重写main函数。 我们可以另写一个main.py,来运行对话框。代码如下:
# -*- coding: utf-8 -*-from PyQt5
import QtWidgetsfrom Dlg
import Ui_Formimport sysif __name__ == "__main__":
app = QtWidgets.QApplication(sys.argv)
myshow = Ui_Form()
myshow.show()
sys.exit(app.exec_())
代码说明:
- 第3行,从对话框文件中导入类,Dlg为对话框文件名;
- 第6行,主程序定义在这行语句下面,输入“main”然后按“Tab”键可快速输入;
运行main.py,即可运行这个对话框程序。
- 快速入门系列--CLR--01基本概念
- 区块链技术的DOS阶段——智能合约上
- mmc如何管理本机上的(数字/x.509)证书
- Jquery $.extend的重载方法详述
- Jquery ajax调用后台aspx后台文件方法(不是ashx)
- [原创]x.509证书在WCF中的应用(CS篇)
- tomcat
- 快速入门系列--WebAPI--01基础
- 分析程序员到底是不是吃青春饭
- Jquery dom搜索之siblings()方法
- 汽车黑科技!想想以后不是我们亲自驾驶汽车还是蛮开心的
- 快速入门系列--CLR--02多线程
- JavaScript之将JS代码放在什么位置最合适
- 快速入门系列--TSQL-01基础概念
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- ES 常用Linux查询命令汇总
- PostgreSql 怎么获取数据库中关键系统信息(一)
- 树莓派基础实验36:通用串口通信实验
- PIMPL:休想窥探我的隐私!
- 树莓派基础实验37:pyserial模块通信实验
- 【答疑解惑】为什么你的 Charles 会抓包失败?
- Mybatis-generator 逆向工程 自定义PO,xml,mapper,example
- 高速上云/网络穿透/视频上云网关EasyNTS组网服务登录状态检测优化记录
- 树莓派基础实验38:逻辑分析仪分析PWM、UART信号
- 【终端设备】视频上云/网络穿透EasyNTS云组网硬件终端无法单独修改账号的优化方式
- 测试环境问题排查的那些事儿
- RTSP流媒体协议视频平台EasyNVR和EasyNTS智能云组网同一浏览器运行为什么会导致EasyNTS无法登陆?
- Java:手写线程安全LRU缓存X探究影响命中率的因素
- 视频上云/网络穿透/网络映射服务EasyNTS设备管理为什么会出现无法搜索到设备的情况?
- 快速打造属于你的接口自动化测试框架