赞
踩
目录
记述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.
注意:
重载参数需要指定参数形式,否则会报错。
3.3 信号与槽的自动连接
- #命名槽函数时使用on_objectname_signalname
- on_okButton_clicked
-
- # 声明完控件之后需要调用以下函数设置自动连接
- QtCore.QMetaObject.connectedSlotByName(self)
QApplication类 用于管理GUI应用程序的控制流和主要设置。
QApplication的主要职责是:
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。