目录
一、PyQt概述
二、第一个PyQt程序
1.一般开发流程
2.HelloWorld
三、PyQt模块基本信息
四、PyQt常用控件介绍
1.布局控件
1.1 QBoxLayout
1.2 QGridLayout
1.3 表单布局
1.4 设置控件的最大值和最小值
1.5 尺寸策略(sizePolicy)
1.6 控件之间的伙伴关系(关联)
1.7 修改控件的tab键顺序
五.事件和事件函数
1. 事件模型
2 重写(Override)事件函数
3 事件过滤器
六.信号和槽
1. 信号和槽的连接
1.1 用代码连接
1.2 在Designer中可以直接编辑信号和槽
1.3 通过QtDesigner为窗口添加菜单和工具栏
2 自定义信号
3 信号和槽间的参数传递
3.1 传递多个参数的信号
3.2 重载形式的信号
4.QtWidgets-用于创建经典UI的类
4.1 QApplication
记述PyQt的相关基本知识。
PyQt是一个创建GUI应用程序的工具包。它是Python编程语言和Qt库的成功融合。Qt库是最强大的库之一。PyQt是由Phil Thompson 开发。
PyQt实现了一个Python模块集。它有超过300类,将近6000个函数和方法。它是一个多平台的工具包,可以运行在所有主要操作系统上,包括UNIX,Windows和Mac。 PyQt采用双许可证,开发人员可以选择GPL和商业许可。在此之前,GPL的版本只能用在Unix上,从PyQt的版本4开始,GPL许可证可用于所有支持的平台。
因为可用的类有很多,他们被分成几个模块。 QtCore模块包含核心的非GUI功能。该模块用于时间、文件和目录、各种数据类型、流、网址、MIME类型、线程或进程。QtGui模块包含图形组件和相关的类,例如按钮、窗体、状态栏、工具栏、滚动条、位图、颜色、字体等。QtNetwork模块包含了网络编程的类,这些类允许编写TCP/IP和UDP的客户端和服务器,他们使网络编程更简单,更轻便。QtXml包含使用XML文件的类,这个模块提供了SAX和DOM API的实现。QtSvg模块提供显示的SVG文件的类。可缩放矢量图形(SVG)是一种用于描述二维图形和图形应用程序的XML语言。QtOpenGL模块使用OpenGL库渲染3D和2D图形,该模块能够无缝集成Qt的GUI库和OpenGL库。QtSql模块提供用于数据库的类。
(以上参考百度百科)
PyQt5和PyQt6的区别:
# _*_ coding:utf-8 _*_
# packages
import sys
from PyQt6.QtWidgets import QApplication,QWidget,QLabel
from PyQt6.QtGui import QIcon,QFont
from PyQt6.QtCore import Qt
class MainWindow(QWidget):
"""
@ 说明:主窗体类
"""
def __init__(self):
"""
@ 主窗体构造函数
"""
super().__init__() # 调用父类构造函数
self.setWindowTitle("Hello world.") # 设置标题
self.setWindowIcon(QIcon("res/Entire Network.ico")) # 设置图标
lab = QLabel("Hello World.",self) # 创建label控件
lab.resize(300,100) # 设置标签尺寸
lab.setFont(QFont("Times new roman",16)) # 设置字体
lab.setAlignment(Qt.AlignmentFlag.AlignCenter) # 设置标签对齐方式
self.show() #显示窗体
if __name__ == "__main__":
app = QApplication(sys.argv) # 创建应用程序,接收命令行参数列表
window = MainWindow() # 创建主窗体实体类
sys.exit(app.exec()) # 程序结束后,调用sys.exit()释放资源
应用程序基本需要的类如下如下:
模块 | 类 | 基本调用 | 说明 |
---|---|---|---|
PyQt6.QtWidgets |
QApplication |
||
QWidget |
class MainWindow(QWidget): |
窗体需要继承自QWidget | |
self.setWindowTitle("Hello world.") |
设置标题 | ||
self.setWindowIcon(QIcon("res/Entire Network.ico")) | 设置图标 |
||
PyQt6.QtGui |
QIcon |
QIcon("res/Entire Network.ico") |
获取QIcon类 |
QFont |
QFont("Times new roman",16) |
获取字体属性,设置控件的文本字体 | |
PyQt6.QtCore |
Qt |
Qt.AlignmentFlag.AlignCenter |
PyQt的枚举参数 |
应用程序编辑基本需要这几个类,然后再添加具体的控件进行界面编辑。
python中imort PyQt6之后使用Help查看具有如下模块
用于对界面进行布局管理的控件或类,不同的布局控件实现不同的布局效果。
QBoxLayout就是一个矩形区域给控件进行垂直或水平分布的布局,由QtWidgets提供。该类派生了QHBoxLayout和QVBoxLayout两个控件分别实现水平布局和垂直布局。
常用属性如下:
常用方法如下:
划分网格的布局,可以将控件划分到不同的单元格。
常用方法:
通过表单工具生成自带标签和单行文本控件的布局控件,通常标签和文本控件成对使用。
常用属性:
通过minimumSize属性控制控件的最小尺寸,通过maximunSize控制控件的最大尺寸。
设置方法如下:
self.setMinimumSize(100,200) # 设置最小尺寸为宽度100,高度200
self.setMinimumWidth(100) # 设置最小宽度为100
self.setMinimumHeight(100) # 设置最小高度为100
self.setMaximumSize(200,400) # 设置最大尺寸为宽度200,高度400
self.setMaximumWidth(200) # 设置最大宽度为200
self.setMaximumHeight(400) # 设置最大高度为400
用于处理控件的尺寸策略。
1.5.1 期望尺寸(sizeHint)
期望尺寸就是在空间自动排版时自动调整的尺寸。
如上图,空间合并布局后就会自动调整尺寸,自动调整的尺寸就是期望尺寸。
对大多数控件来说,期望尺寸是 只读的。
self.btn = QPushButton()
self.btn.sizeHint() # 获取期望尺寸
self.btn.sizeHint().width() # 获取期望尺寸的宽度
self.btn.sizeHint().height() # 获取期望尺寸的高度
self.btn.minimumSizeHint() # 期望的最小尺寸
1.5.2 策略方案
编辑控件后,可以通过关联的伙伴进行控制,比如通过标签设置快捷键,然后用快捷键控制标签的伙伴文本框。
1.6.1 Designer编辑伙伴关系
使用通过点击菜单按钮或者Edit-编辑伙伴菜单进入伙伴关系编辑
然后鼠标左键点击控件,拖拽到要管理的控件上。
切换到窗口编辑界面可以推出。
1.7.1 Designer编辑tab顺序
使用通过点击编辑Tab顺序菜单或者Edit-编辑Tab顺序菜单进入。
双击顺序方框进行修改。
或者通过右键点击顺序框,然后选择“制表符顺序列表菜单”然后进行修改
PyQt全部事件函数:
进行修改时只需要对对应的事件函数进行重写即可。
def 事件函数名称(self, evt):
代码段
使用事件过滤器可以屏蔽特定的事件,也可以在事件被处理前插入其他操作。是否用方法如下:
1. 重写QQbject.eventFilter过滤器
2.调用QApplication.installEventFilter安装事件过滤器
def eventFilter(self, objwatched, evt):
"""事件过滤器"""
if evt.type() == QEvent.Type.KeyPress.value:
...
return True
return super().eventFilter(objwatched, evt)
### 主程序中调用
app = QApplication(sys.argv)
win = MyWindow()
app.installEventFilter(win)
sys.exit(app.exec())
信号(Signals)类似于事件,槽(Slots)用来接受信号,支持自定义槽。
使用Signals.connect(Slots)将信号的槽连接在一起。
有点类似于Wpf中的bing,数据绑定在一起,可以更便捷的实现数据变化显示。
断开连接,使用Signals.disconnect(Slots)断开信号与槽的连接。
通过信号/槽菜单或者Edit-信号和槽进行编辑。
点击控件,然后拖拽到旁边(与窗口相连),或者拖拽到具体要接收信号的控件上(与具体控件相连)进行创建信号,在弹出的信号和槽编辑窗口中编辑具体的信号和槽。
同佳佳菜单栏后,通过动作编辑器添加具体的菜单和动作,然后将动作拖拽到菜单栏或者工具栏中。
通过继承QObject类,然后实例化pyqtSignal来自定义信号。
# _*_ coding:utf-8 _*_
from PyQt5.QtWidgets import QWidget,QPushButton,QLabel,QMainWindow
from PyQt5.QtCore import QObject,pyqtSignal
class SendSignal(QObject):
"""信号类"""
sendmsg = pyqtSignal(object) # 定义一个参数的信号
def run(self):
"""函数"""
self.sendmsg.emit("Hello.")
class GetSlot(QObject):
def get(self,msg):
"""接收信号信息"""
print("Get signal msg : ", msg)
if __name__ == "__main__":
send = SendSignal()
slot = GetSlot()
# 连接信号与槽
send.sendmsg.connect(slot.get)
print("Connected.")
send.run()
# 断开连接
send.sendmsg.disconnect(slot.get)
print("Disconnected.")
send.run()
注意:
接收的槽函数参数需要与信号的参数保持一致。
# 信号
signal = pyqtSignal(type1,type2,type3,...)
# 槽
def slot(type1,type2,type3,...):
代码块
定义信号的时候使用多个参数类型,同时定义多个参数,接收的槽函数的参数与信号保持一致。
# 重载形式信号,信号可以是任意一个[]中的信号形式
signal = pyqtSignal([int,str],[str],[...])
# 槽,槽需要指定要接收的信号形式
signal[int,str].emit(...)
signal[int,str].connect(slot)
def slot(self,int,str):
代码块:
# 重载
signal[str].emit(...)
signal[str].connect(slot)
def slot(self,str):
代码块:
示例:
# _*_ coding:utf-8 _*_
from PyQt5.QtWidgets import QWidget,QPushButton,QLabel,QMainWindow
from PyQt5.QtCore import QObject,pyqtSignal
class SendSignal(QObject):
"""信号类"""
sendmsg = pyqtSignal(object) # 定义一个参数的信号
sendparams = pyqtSignal(int,str,str) # 定义多个参数的信号
sendoverride = pyqtSignal([int, str], [str]) # 定义重载参数的信号
def run(self):
"""函数"""
self.sendmsg.emit("Hello.")
self.sendparams.emit(1,"Hello","Nice to meet you.")
self.sendoverride[str].emit( "Hello")
self.sendoverride[int, str].emit(1, "Nice to meet you.")
class GetSlot(QObject):
def get(self, msg):
"""接收信号信息"""
print("Get signal msg : ", msg)
def getparams(self, index, title, msg):
"""接收信号信息"""
print("Index : {},Type: {},msg : {}".format(index, title, msg))
def getoverride(self, index, msg):
"""接收信号信息"""
print("Index : {},msg : {}".format(index, msg))
if __name__ == "__main__":
send = SendSignal()
slot = GetSlot()
# 连接信号与槽
send.sendmsg.connect(slot.get)
send.sendparams.connect(slot.getparams)
send.sendoverride[str].connect(slot.get)
send.sendoverride[int, str].connect(slot.getoverride)
print("Connected.")
send.run()
# 断开连接
send.sendmsg.disconnect(slot.get)
send.sendparams.disconnect(slot.getparams)
send.sendoverride[str].disconnect(slot.get)
send.sendoverride[int, str].disconnect(slot.getoverride)
print("Disconnected.")
send.run()
结果:
Connected.
Get signal msg : Hello.
Index : 1,Type: Hello,msg : Nice to meet you.
Get signal msg : Hello
Index : 1,msg : Nice to meet you.
Disconnected.
注意:
重载参数需要指定参数形式,否则会报错。
QApplication类 用于管理GUI应用程序的控制流和主要设置。
QApplication的主要职责是: