PyQt5通信机制 信号与槽详解


Posted in Python onAugust 07, 2019

 前言

信号和槽是PyQt编程对象之间进行通信的机制。每个继承自QWideget的控件都支持信号与槽机制。信号发射时(发送请求),连接的槽函数就会自动执行(针对请求进行处理)。本文主要讲述信号和槽最基本、最经常使用方法。就是内置信号和槽的使用的使用方法。

内置信号和槽

所谓内置信号与槽的使用。是指在发射信号时,使用窗口控件的函数,而不是自定义的函数。信号与槽的连接方法是通过QObject.signal.connect将一个QObject的信号连接到另一个QObject的槽函数。

在任何GUI设计中,按钮都是最重要的和常用的触发动作请求的方式,用来与用户进行交互操作。常见的按钮包括QPushButton、QRadioButton和QCheckBox。这些按钮都继承自QAbstractButton类,QAbstractButton提供的信号包括:

Clicked:鼠标左键点击按钮并释放触发该信号。最常用。记住这个就差不多够了。

Pressed:鼠标左键按下时触发该信号

Released:鼠标左键释放时触发该信号

Toggled:控件标记状态发生改变时触发该信号。

内置信号和槽使用实例

这里实现一个点击按钮退出界面需求实现过程来介绍内置信号和槽。开始动手。。。

Step1:打开Qt Designer,选择Widget模板。在工具箱中拖动Push Button控件按钮到主界面。并修改控件显示名称。保存为singal.ui。界面如下:

PyQt5通信机制 信号与槽详解

Step2:使用pyuic5 -o singal.py singal.ui转换成.py格式。

Step3:为考虑介绍方便,将调用程序在singal.py中主程序。其中MyMainForm类中的命令行为Push Button按钮点击信号添加槽函数。如下

self.pushButton.clicked.connect(self.close)

完整代码如下(可直接拷贝运行,字体加粗部分为添加部分):

# -*- coding: utf-8 -*-
# Form implementation generated from reading ui file 'signal.ui'
#
# Created by: PyQt5 UI code generator 5.11.3
#
# WARNING! All changes made in this file will be lost!
import sys
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtWidgets import QApplication, QMainWindow, QMessageBox
class Ui_Form(object):
  def setupUi(self, Form):
    Form.setObjectName("Form")
    Form.resize(431, 166)
    self.pushButton = QtWidgets.QPushButton(Form)
    self.pushButton.setGeometry(QtCore.QRect(160, 50, 91, 41))
    font = QtGui.QFont()
    font.setFamily("YaHei Consolas Hybrid")
    font.setPointSize(14)
    self.pushButton.setFont(font)
    self.pushButton.setObjectName("pushButton")
    self.retranslateUi(Form)
    QtCore.QMetaObject.connectSlotsByName(Form)
  def retranslateUi(self, Form):
    _translate = QtCore.QCoreApplication.translate
    Form.setWindowTitle(_translate("Form", "信号与槽"))
    self.pushButton.setText(_translate("Form", "关闭"))

class MyMainForm(QMainWindow, Ui_Form):
  def __init__(self, parent=None):
    super(MyMainForm, self).__init__(parent)
    self.setupUi(self)
    self.pushButton.clicked.connect(self.close)
if __name__ == "__main__":
  app = QApplication(sys.argv)
  myWin = MyMainForm()
  myWin.show()
  sys.exit(app.exec_())

运行并点击如下按钮就可以关闭窗口

PyQt5通信机制 信号与槽详解

内置信号和自定义槽使用实例

实现过程同上述步骤一样。槽函数showMsg为自定义函数。

信号与槽:self.pushButton.clicked.connect(self.showMsg)

完整代码如下(可直接拷贝运行,字体加粗部分为添加部分):

# -*- coding: utf-8 -*-
# Form implementation generated from reading ui file 'signal.ui'
#
# Created by: PyQt5 UI code generator 5.11.3
#
# WARNING! All changes made in this file will be lost!
import sys
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtWidgets import QApplication, QMainWindow, QMessageBox
class Ui_Form(object):
  def setupUi(self, Form):
    Form.setObjectName("Form")
    Form.resize(431, 166)
    self.pushButton = QtWidgets.QPushButton(Form)
    self.pushButton.setGeometry(QtCore.QRect(160, 50, 91, 41))
    font = QtGui.QFont()
    font.setFamily("YaHei Consolas Hybrid")
    font.setPointSize(14)
    self.pushButton.setFont(font)
    self.pushButton.setObjectName("pushButton")
    self.retranslateUi(Form)
    QtCore.QMetaObject.connectSlotsByName(Form)
  def retranslateUi(self, Form):
    _translate = QtCore.QCoreApplication.translate
    Form.setWindowTitle(_translate("Form", "信号与槽"))
    self.pushButton.setText(_translate("Form", "运行"))
class MyMainForm(QMainWindow, Ui_Form):
  def __init__(self, parent=None):
    super(MyMainForm, self).__init__(parent)
    self.setupUi(self)
    self.pushButton.clicked.connect(self.showMsg)
  def showMsg(self):
    QMessageBox.information(self, "信息提示框", "OK,内置信号与自定义槽函数!")

if __name__ == "__main__":
  app = QApplication(sys.argv)
  myWin = MyMainForm()
  myWin.show()
  sys.exit(app.exec_())

运行结果如下:

PyQt5通信机制 信号与槽详解

Qt Designer添加控件信号与槽

上述介绍的内容是通过代码方式实现内置信号与槽的连接。那Qt Designer工具可以实现信号与槽的连接?之前在第二节课Qt Designer主界面介绍时提过信号槽区域。一直没有讲如何使用。通过这个区域功能是可以实现信号与槽的连接的。

还是以添加内置信号与槽来介绍。

Step1:打开Qt Designer界面,找到信号槽编辑区。如下

PyQt5通信机制 信号与槽详解

Step2:点击+号 Sender控件选择"PushButton"、Signal信号选择"clicked",Receiver选择"Form",内置槽函数选择"close()"

PyQt5通信机制 信号与槽详解

Step3:保存.ui格式,并使用pyuic转换成.py格式,添加调用程序,运行。效果一样。这些步骤都介绍过,不再重复介绍,关键代码如下:

PyQt5通信机制 信号与槽详解

小结

本文介绍了PyQt5信号与槽最基本的使用方法。知道如何在Qt Designer生成的.py文件中添加控件信号与槽的关系并且知道如何调用自定义槽函数。掌握了这些,应该就可以动手实现一些基本的需求了。

到这里,按照这几个章节的介绍应该可以动手完成简单需求的实现。至于更进一步的学习,可以通过实践过程中遇到的问题以及小工具开发需求去驱动加深理解可能效果会好一点。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python自动安装pip
Apr 24 Python
详解Python的Django框架中的模版相关知识
Jul 15 Python
在Django同1个页面中的多表单处理详解
Jan 25 Python
Python通过matplotlib画双层饼图及环形图简单示例
Dec 15 Python
python 批量修改/替换数据的实例
Jul 25 Python
pygame游戏之旅 添加游戏界面按键图形
Nov 20 Python
浅谈python 读excel数值为浮点型的问题
Dec 25 Python
python 自动批量打开网页的示例
Feb 21 Python
Python实现语音识别和语音合成功能
Sep 20 Python
selenium切换标签页解决get超时问题的完整代码
Aug 30 Python
Python-typing: 类型标注与支持 Any类型详解
May 10 Python
浅谈Python数学建模之线性规划
Jun 23 Python
python 使用socket传输图片视频等文件的实现方式
Aug 07 #Python
python获取Pandas列名的几种方法
Aug 07 #Python
python 提取文件指定列的方法示例
Aug 07 #Python
PyQt Qt Designer工具的布局管理详解
Aug 07 #Python
Python BeautifulSoup [解决方法] TypeError: list indices must be integers or slices, not str
Aug 07 #Python
python利用7z批量解压rar的实现
Aug 07 #Python
django基础学习之send_mail功能
Aug 07 #Python
You might like
人大复印资料处理程序_查询篇
2006/10/09 PHP
php 模拟POST|GET操作实现代码
2010/07/20 PHP
laravel利用中间件防止未登录用户直接访问后台的方法
2019/09/30 PHP
两个select之间option的互相添加操作(jquery实现)
2009/11/12 Javascript
javascript中强制执行toString()具体实现
2013/04/27 Javascript
jQuery的text()方法用法分析
2014/12/20 Javascript
js验证上传图片的方法
2015/05/12 Javascript
JavaScript中的Math.LN2属性用法详解
2015/06/12 Javascript
只要1K 纯JS脚本送你一朵3D红色玫瑰
2016/08/09 Javascript
AngularJS通过$sce输出html的方法
2016/09/22 Javascript
javascript数据结构中栈的应用之符号平衡问题
2017/04/11 Javascript
node.js实现微信JS-API封装接口的示例代码
2017/09/06 Javascript
AngularJS实现的select二级联动下拉菜单功能示例
2017/10/25 Javascript
旺旺在线客服代码 旺旺客服代码生成器
2018/01/09 Javascript
JavaScript数组方法的错误使用例子
2018/09/13 Javascript
如何在 Vue 表单中处理图片
2021/01/26 Vue.js
[02:03]完美世界DOTA2联赛10月30日赛事集锦
2020/10/31 DOTA
Python3基础之基本数据类型概述
2014/08/13 Python
浅谈python中str字符串和unicode对象字符串的拼接问题
2018/12/04 Python
利用python修改json文件的value方法
2018/12/31 Python
Python基于matplotlib画箱体图检验异常值操作示例【附xls数据文件下载】
2019/01/07 Python
python将YUV420P文件转PNG图片格式的两种方法
2021/01/22 Python
css3编写浏览器背景渐变背景色的方法
2018/03/05 HTML / CSS
Html5实现单张、多张图片上传功能
2019/04/28 HTML / CSS
美国男士内衣品牌:Tommy John
2017/12/22 全球购物
大学自主招生自荐信
2013/12/16 职场文书
大学生志愿者感言
2014/01/15 职场文书
妇产医师自荐信
2014/01/29 职场文书
小学教师听课制度
2014/02/01 职场文书
《小松树和大松树》教学反思
2014/02/20 职场文书
工艺工程师岗位职责
2014/03/04 职场文书
小学校园之星事迹材料
2014/05/16 职场文书
幼儿园六一活动总结
2014/08/27 职场文书
以权谋私检举信范文
2015/03/02 职场文书
返乡农民工证明
2015/06/24 职场文书
一条 SQL 语句执行过程
2022/03/17 MySQL