pyqt中细分:信号与槽 pyqt 信号 槽
itomcoil 2024-12-22 18:54 48 浏览
1、分类
信号分为:内置信号和自定义信号;
槽函数分为:内置槽函数和自定义槽函数;
根据排列组合规律,可分为4中情况,如下:
(1)内置信号和内置槽函数
(2)内置信号与自定义槽函数
(3)自定义信号与内置槽函数
(4)自定义信号与自定义槽函数
2、定义解释
(1)内置信号
在 PyQt 中,内置信号是指由 PyQt 框架提供的预定义信号,这些信号通常与用户界面的交互动作相关。内置信号使得开发者能够轻松地连接到特定的用户操作,并在这些操作发生时执行相应的处理。
内置信号通常由 PyQt 中的各种用户界面组件(如按钮、文本框、滑块等)发出,这些组件可以是 PyQt 提供的标准组件,也可以是自定义的组件。每个组件都有其特定的内置信号。
以下是一些常见的 PyQt 内置信号以及它们的解释:
- clicked():当按钮被点击时发出的信号。
- pressed():当按钮被按下时发出的信号。
- released():当按钮被释放时发出的信号。
- textChanged():当文本框内容发生变化时发出的信号。
- currentIndexChanged():当下拉框(ComboBox)的当前选项发生变化时发出的信号。
- valueChanged():当滑块(Slider)的值发生变化时发出的信号。
- editingFinished():当编辑框(LineEdit)的编辑完成时发出的信号。
- toggled():当复选框(CheckBox)状态切换时发出的信号。
连接内置信号到槽函数的方式通常是使用 connect() 方法。例如:
button.clicked.connect(self.on_button_clicked)
这行代码将按钮的 clicked() 信号连接到了一个名为 on_button_clicked() 的槽函数上。
(2)自定义信号
在 PyQt 中,你可以创建自定义信号以实现更高级的用户界面交互。自定义信号允许你在你的应用程序中定义特定事件,并在这些事件发生时发射信号,让其他部分能够捕获并做出响应。这种机制非常有用,因为它使得不同组件之间的通信变得更加灵活和高效。
要创建自定义信号,你需要使用 QtCore 模块中的 pyqtSignal() 方法。以下是一个简单的例子:
from PyQt5.QtCore import QObject, pyqtSignal
class MyObject(QObject):
# 定义一个自定义信号,参数类型为字符串
my_signal = pyqtSignal(str)
def __init__(self):
super().__init__()
def do_something(self):
# 当执行某些操作时,发射自定义信号,并传递参数
self.my_signal.emit("Custom signal emitted!")
(3)内置槽函数
在 PyQt 中,内置槽函数是一组预定义的方法,用于处理用户界面中的各种事件和操作。这些内置槽函数可以直接应用于 PyQt 提供的各种控件,例如按钮、文本框、滑块等,以便执行特定的功能。
以下是一些常见的 PyQt 内置槽函数及其功能:
- setText(text: str):设置控件的文本内容。
- setEnabled(enabled: bool):设置控件是否可用。
- setVisible(visible: bool):设置控件是否可见。
- clicked(bool checked = False):处理按钮点击事件。参数 checked 指示按钮是否被选中。
- show():显示控件。
- hide():隐藏控件。
- clear():清除控件中的内容,如清除文本框中的文本。
- valueChanged(int value):处理控件值的变化事件,比如滑块的值发生变化。
这些槽函数可以通过控件对象直接调用,也可以与信号连接,以便在信号触发时自动调用。例如,将按钮的 clicked() 信号连接到一个槽函数:
button.clicked.connect(self.on_button_clicked)
当按钮被点击时,on_button_clicked 槽函数就会被调用。
(4)自定义槽函数
在 PyQt 中,自定义槽函数是用户定义的用于处理信号的函数,使用关键字(如 def)定义。槽函数是普通的 Python 方法,它们可以连接到 PyQt 控件发出的信号,并在信号触发时执行特定的操作。
要定义一个自定义槽函数,只需在你的类中创建一个普通的方法,并将其用作槽函数。然后,你可以使用 connect() 方法将该槽函数与信号关联起来,以便在信号触发时自动调用该函数。
自定义槽函数 的命名规则通常遵循以下约定:
- 以 on_ 开头
- 接着是控件的名称
- 然后是下划线
- 最后是信号的名称
以下是一个简单的示例,展示了如何在 PyQt 中定义和使用自定义槽函数:
from PyQt5.QtWidgets import QApplication, QMainWindow, QPushButton
class MyWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("PyQt Example")
# 创建一个按钮
self.button = QPushButton('Click me', self)
self.button.setGeometry(100, 100, 100, 50)
# 连接按钮的 clicked 信号到自定义的槽函数
self.button.clicked.connect(self.on_button_clicked)
# 自定义的槽函数
def on_button_clicked(self):
print('Custom slot called!')
if __name__ == '__main__':
app = QApplication([])
window = MyWindow()
window.show()
app.exec_()
在这个示例中,我们定义了一个名为 on_button_clicked的自定义槽函数,并将按钮的 clicked 信号连接到它上面。当按钮被点击时,on_button_clicked 槽函数就会被调用,并输出 "Custom slot called!"。
3、举例说明
(1)内置信号和自定义槽函数
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QLineEdit, QPushButton
class QmyWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("内置信号和内置槽函数示例") # 设置窗口标题
self.setGeometry(100, 100, 400, 200) # 设置窗口大小
self.button = QPushButton("click me", self) # 创建一个按钮, 按钮上显示"click me"
self.button.setGeometry(150, 50, 100, 30) # 设置按钮的位置和大小
self.textbox = QLineEdit(self) # 创建一个文本框
self.textbox.setGeometry(100, 100, 200, 30) # 设置文本框的位置和大小
# 将按钮的内置clicked信号连接到内置槽函数setText()
self.button.clicked.connect(lambda: self.textbox.setText("Button Clicked"))
if __name__ == "__main__":
app = QApplication(sys.argv)
myWin = QmyWindow()
myWin.show()
sys.exit(app.exec_())
(2)内置函数和自定义槽函数
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QLineEdit, QPushButton
class QmyWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("内置信号和内置槽函数示例") # 设置窗口标题
self.setGeometry(100, 100, 400, 200) # 设置窗口大小
self.button = QPushButton("click me", self) # 创建一个按钮, 按钮上显示"click me"
self.button.setGeometry(150, 50, 100, 30) # 设置按钮的位置和大小
self.textbox = QLineEdit(self) # 创建一个文本框
self.textbox.setGeometry(100, 100, 200, 30) # 设置文本框的位置和大小
self.button.clicked.connect(self.on_button_clicked) # 将按钮的clicked信号连接到on_button_clicked槽函数
self.textbox.textChanged.connect(self.on_textbox_textChanged) # 将文本框的textChanged信号连接到text_changed槽函数
def on_button_clicked(self): # 内置槽函数on_button_clicked()
print("button clicked") # 打印"button clicked"
def on_textbox_textChanged(self): # 自定义槽函数text_changed()
print("text changed") # 打印"text changed"
if __name__ == "__main__":
app = QApplication(sys.argv)
myWin = QmyWindow()
myWin.show()
sys.exit(app.exec_())
(3)自定义信号和内置槽函数
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QPushButton,QLineEdit
from PyQt5.QtCore import QObject, pyqtSignal
class QmyObject(QObject):
mySignal = pyqtSignal(str) # 创建一个信号对象mySignal
def some_method(self):
self.mySignal.emit("custom signal,emitted") # 发射信号
class QmyWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("自定义信号和内置槽函数示例") # 设置窗口标题
self.setGeometry(100, 100, 400, 200) # 设置窗口大小
self.button = QPushButton("click me", self) # 创建一个按钮, 按钮上显示"click me"
self.button.setGeometry(150, 50, 100, 30) # 设置按钮的位置和大小
self.textbox = QLineEdit(self) # 创建一个文本框
self.textbox.setGeometry(100, 100, 200, 30)
self.obj = QmyObject() # 创建一个QmyObject对象obj
# 将obj的mySignal自定义信号连接到lambda表达式, lambda表达式将text设置为文本框的文本,setText()是内置槽函数
self.obj.mySignal.connect(lambda text: self.textbox.setText(text))
# 将按钮的内置clicked信号连接到obj的some_method自定义槽函数
self.button.clicked.connect(self.obj.some_method)
if __name__ == "__main__":
app = QApplication(sys.argv)
myWin = QmyWindow()
myWin.show()
sys.exit(app.exec_())
4、自定义信号和自定义槽函数
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QPushButton, QLineEdit
from PyQt5.QtCore import QObject, pyqtSignal
class QmyObject(QObject):
mySignal = pyqtSignal(str) # 创建一个信号对象mySignal
def some_method(self):
self.mySignal.emit("custom signal,emitted") # 发射信号
class QmyWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("自定义信号和自定义槽函数示例") # 设置窗口标题
self.setGeometry(100, 100, 400, 200) # 设置窗口大小
self.button = QPushButton("click me", self) # 创建一个按钮, 按钮上显示"click me"
self.button.setGeometry(150, 50, 100, 30) # 设置按钮的位置和大小
self.textbox = QLineEdit(self) # 创建一个文本框
self.textbox.setGeometry(100, 100, 200, 30)
# 创建一个QmyObject对象obj
self.obj = QmyObject()
# 自定义信号与自定义槽函数的连接
self.obj.mySignal.connect(self.on_mySignal)
# 将按钮的内置clicked信号连接到obj的some_method自定义槽函数
self.button.clicked.connect(self.obj.some_method)
# 将按钮的内置clicked信号连接到lambda表达式, lambda表达式将text设置为文本框的文本,setText()是内置槽函数
self.button.clicked.connect(lambda: self.textbox.setText("Button Clicked"))
def on_mySignal(self, message): # 自定义槽函数on_mySignal()
print("receive:", message) # 打印message
if __name__ == "__main__":
app = QApplication(sys.argv)
myWin = QmyWindow()
myWin.show()
sys.exit(app.exec_())
相关推荐
- 《Queendom》宣布冠军!女团MAMAMOO四人激动落泪
-
网易娱乐11月1日报道据台湾媒体报道,南韩女团竞争回归的生死斗《Queendom》昨(10/31)晚播出大决赛,并以直播方式进行,6组女团、女歌手皆演唱新歌,并加总前三轮的赛前赛、音源成绩与直播现场投...
- 正确复制、重写别人的代码,不算抄袭
-
我最近在一篇文章提到,工程师应该怎样避免使用大量的库、包以及其他依赖关系。我建议的另一种方案是,如果你没有达到重用第三方代码的阈值时,那么你就可以自己编写代码。在本文中,我将讨论一个在重用和从头开始编...
- HTML DOM tr 对象_html event对象
-
tr对象tr对象代表了HTML表格的行。HTML文档中出现一个<tr>标签,就会创建一个tr对象。tr对象集合W3C:W3C标签。集合描述W3Ccells返回...
- JS 打造动态表格_js如何动态改变表格内容
-
后台列表页最常见的需求:点击表头排序+一键全选。本文用原生js代码实现零依赖方案,涵盖DOM查询、排序算法、事件代理三大核心技能。效果速览一、核心思路事件入口:为每个<th>绑...
- 连肝7个晚上,总结了66条计算机网络的知识点
-
作者|哪吒来源|程序员小灰(ID:chengxuyuanxiaohui)计算机网络知识是面试常考的内容,在实际工作中经常涉及。最近,我总结了66条计算机网络相关的知识点。1、比较http0....
- Vue 中 强制组件重新渲染的正确方法
-
作者:MichaelThiessen译者:前端小智来源:hackernoon有时候,依赖Vue响应方式来更新数据是不够的,相反,我们需要手动重新渲染组件来更新数据。或者,我们可能只想抛开当前的...
- 为什么100个前端只有1人能说清?浏览器重排/重绘深度解析
-
面试现场的"致命拷问""你的项目里做过哪些性能优化?能具体讲讲重排和重绘的区别吗?"作为面试官,我在秋招季连续面试过100多位前端候选人,这句提问几乎成了必考题。但令...
- HTML DOM 介绍_dom4j html
-
HTMLDOM(文档对象模型)是一种基于文档的编程接口,它是HTML和XML文档的编程接口。它可以让开发人员通过JavaScript或其他脚本语言来访问和操作HTML和XML文档...
- JavaScript 事件——“事件流和事件处理程序”的注意要点
-
事件流事件流描述的是从页面中接收事件的顺序。IE的事件流是事件冒泡流,而NetscapeCommunicator的事件流是事件捕获流。事件冒泡即事件开始时由最具体的元素接收,然后逐级向上传播到较为不...
- 探秘 Web 水印技术_水印制作网页
-
作者:fransli,腾讯PCG前端开发工程师Web水印技术在信息安全和版权保护等领域有着广泛的应用,对防止信息泄露或知识产品被侵犯有重要意义。水印根据可见性可分为可见水印和不可见水印(盲水印)...
- 国外顶流网红为流量拍摄性侵女学生?仅被封杀三月,回归仍爆火
-
曾经的油管之王,顶流网红DavidDobrik复出了。一切似乎都跟他因和成员灌酒性侵女学生被骂到退网之前一样:住在950万美元的豪宅,开着20万美元的阿斯顿马丁,每条视频都有数百万观看...人们仿佛...
- JavaScript 内存泄漏排查方法_js内存泄漏及解决方法
-
一、概述本文主要介绍了如何通过Devtools的Memory内存工具排查JavaScript内存泄漏问题。先介绍了一些相关概念,说明了Memory内存工具的使用方式,然后介绍了堆快照的...
- 外贸独立站,网站优化的具体内容_外贸独立站,网站优化的具体内容有哪些
-
Wordpress网站优化,是通过优化代码、数据库、缓存、CSS/JS等内容,提升网站加载速度、交互性和稳定性。网站加载速度,是Google搜索引擎的第一权重,也是SEO优化的前提。1.优化渲染阻塞。...
- 这8个CSS工具可以提升编程速度_css用什么编译器
-
下面为大家推荐的这8个CSS工具,有提供函数的,有提供类的,有提取代码的,还有收集CSS的统计数据的……请花费两分钟的时间看完这篇文章,或许你会找到意外的惊喜,并且为你的编程之路打开了一扇新的大门。1...
- vue的理解-vue源码 历史 简介 核心特性 和jquery区别 和 react对比
-
一、从历史说起Web是WorldWideWeb的简称,中文译为万维网我们可以将它规划成如下的几个时代来进行理解石器时代文明时代工业革命时代百花齐放时代石器时代石器时代指的就是我们的静态网页,可以欣...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)