个人理解:pyqt5的信号就是C++中事件,比如鼠标单击事件;pyqt5中的槽就是c++事件函数,比如单击之后要去执行的函数

例子一 一个信号连接一个槽

import sys
from PyQt5.QtWidgets import QApplication, QWidget, QPushButton class Demo(QWidget): # 1
def __init__(self):
super(Demo, self).__init__() #注意:要传入(Demo, self)
self.button = QPushButton('Start', self) # 2
self.button.clicked.connect(self.change_text) # 3 def change_text(self): #槽函数
self.button.setText('Stop') #设置按钮显示的文本
self.button.clicked.disconnect(self.change_text) #信号和槽函数解绑,解绑后再单击按钮也不会执行槽函数
if __name__ == '__main__':
app = QApplication(sys.argv)
demo = Demo() # 6
demo.show() # 7
sys.exit(app.exec_()) #1:该类从QWidget类继承,可以将QWidget看作是一种毛坯房【Demo看作容器】,还没有装修,而我们往其中放入QPushButton、QLabel等控件就相当于在装修这间毛坯房
#2:实例化一个QPushButton,参数self不能忘了(相当于告诉程序这个QPushButton是放在self中);参数1是要显示的文本
#3:连接信号与槽函数。self.button控件被单击时,就去执行函数self.change_text【clicked是信号;self.change_text是槽函数】
例子二  多个信号连接同一个槽

import sys
from PyQt5.QtWidgets import QApplication, QWidget, QPushButton class Demo(QWidget):
def __init__(self):
super(Demo, self).__init__()
self.button = QPushButton('Start', self)
self.button.pressed.connect(self.change_text) #鼠标左键按下时
self.button.released.connect(self.change_text) #鼠标左键释放时 def change_text(self):
if self.button.text() == 'Start':
self.button.setText('Stop')
else:
self.button.setText('Start') if __name__ == '__main__':
app = QApplication(sys.argv)
demo = Demo()
demo.show()
sys.exit(app.exec())

例子三 一个信号连接另一个信号

import sys
from PyQt5.QtWidgets import QApplication, QWidget, QPushButton class Demo(QWidget):
def __init__(self):
super(Demo, self).__init__()
self.button = QPushButton('Start', self)
self.button.pressed.connect(self.button.released)
#将pressed信号和released信号连接起来,而released信号则与槽函数连接。这样当点击不放时,pressed信号发出,released信号也会发出,从而启动槽函数。释放鼠标则发出released信号,再次启动槽函数
self.button.released.connect(self.change_text) #鼠标左键释放时 def change_text(self):
if self.button.text() == 'Start':
self.button.setText('Stop')
else:
self.button.setText('Start') if __name__ == '__main__':
app = QApplication(sys.argv)
demo = Demo()
demo.show()
sys.exit(app.exec())

例子4 一个信号连接多个槽

import sys
from PyQt5.QtWidgets import QApplication, QWidget, QPushButton class Demo(QWidget):
def __init__(self):
super(Demo, self).__init__()
self.resize(300, 300) #设置窗口大小
self.setWindowTitle('我的qt5练习') #设置窗口标题
self.button = QPushButton('Start', self)
self.button.clicked.connect(self.change_text)
self.button.clicked.connect(self.change_window_size)
self.button.clicked.connect(self.change_window_title)
#鼠标单击信号连接了三个函数 def change_text(self):
self.button.setText('停止')
self.button.clicked.disconnect(self.change_text) def change_window_size(self):
self.resize(500, 500)
self.button.clicked.disconnect(self.change_window_size) def change_window_title(self):
self.setWindowTitle('窗口标题发生改变')
self.button.clicked.disconnect(self.change_window_title) if __name__ == '__main__':
app = QApplication(sys.argv)
demo = Demo()
demo.show()
sys.exit(app.exec())

例子五---自定义信号

from PyQt5.QtWidgets import QApplication, QWidget,QPushButton
from PyQt5.QtCore import Qt
import sys
from PyQt5.QtCore import pyqtSignal #自定义信号模块 class Btn(QPushButton):
#rightclicked= pyqtSignal() #实例化一个自定义信号,在类内的自定义信号必须是类属性 #rightclicked= pyqtSignal(str)
#参数 可选 str---发出信号时向槽函数传递一个字符串
#【传递的数据类型,可以自己决定】 #rightclicked = pyqtSignal([str],[int])
#传递的参数有可能是字符串,有可能是整型数据,传递一个参数
#第一个是默认的 rightclicked = pyqtSignal([str,int])
#向槽函数传递两个参数 一个是str类型 一个是int类型 def mousePressEvent(self, event): # 鼠标键按下时调用
super().mousePressEvent(event) #执行父类的鼠标事件
#如果不行行父类,父类的鼠标左键单击事件等会被覆盖
n = event.button()
if n==Qt.RightButton:
#self.rightclicked.emit() #发出自定义信号 #self.rightclicked.emit('李明')
#参数 向常函数传递的文本字符串 #self.rightclicked[str].emit('李明')
#[str] 表示传递的参数类型是str self.rightclicked[str,int].emit('李明',867) class win(QWidget):
def __init__(self):
super().__init__()
self.resize(300,300)
self.pb=Btn('按钮',self)
self.pb.move(50,100)
self.pb.clicked.connect(self.AA) #self.pb.rightclicked.connect(self.BB)
self.pb.rightclicked[str,int].connect(self.BB)
#[str] 指明接受的参数类型是str def AA(self):
print('点击了鼠标左键')
# def BB(self):
# print('点击了鼠标右键') def BB(self,t,i):
print('点击了鼠标右键',t,i) if __name__=='__main__':
app=QApplication(sys.argv)
w=win()
w.show()
sys.exit(app.exec_())

装饰器连接信号与槽--根据setObjectName的值连接槽函数

王顺子 388

from PyQt5.QtWidgets import QApplication, QWidget,QPushButton
from PyQt5.QtCore import Qt,pyqtSlot
import sys
from PyQt5 import QtCore class win(QWidget):
def __init__(self):
super().__init__()
self.resize(300,300)
self.btn=QPushButton('按钮',self)
self.btn.move(50,100)
self.btn.setObjectName('btn') QtCore.QMetaObject.connectSlotsByName(self) #将参数内部的子孙对象的信号, 根据objectName连接到相关的槽函数
#注意 这句要防止控件创建之后 setObjectName之后 @pyqtSlot(bool) #bool 接受数据的类型--可选
def on_btn_clicked(self,v):#格式:ON_setObjectName的值_信号动作
print('点击了鼠标左键',v) if __name__=='__main__':
app=QApplication(sys.argv)
w=win()
w.show()
sys.exit(app.exec_())

												

pyqt5-信号与槽的更多相关文章

  1. [ PyQt入门教程 ] PyQt5信号与槽

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

  2. pyqt5信号与槽2

    信号和槽与类的属性和方法在层次上是相同的,同属与一个类的特征. 信号的定义由工厂函数生成: signal=PyQt5.QtCore.pyqtSignal(types[, name[, result[, ...

  3. PyQt5信号与槽详解

    1.信号与槽函数基础'''信号与槽函数基础,信号是一个事件,发射信号之后槽函数就会执行'''from PyQt5.QtWidgets import *import sys class signal(Q ...

  4. PyQt5信号与槽关联的两种方式

    目录 通过QtDesigner 手动关联的方式 通过QtDesigner 单击菜单栏切换到信号槽编辑模式 单击控件并拖动鼠标到信号的接收对象上,一般为对话框自己,松开鼠标弹出信号和槽选择框 选中cli ...

  5. PyQt5信号与槽

    简单使用 可以使用designer的一个模式定义,也可以自己定义,在__init__函数里,self.btn.clicked.connect(self.text.clear). 注意:槽不用加括号,可 ...

  6. PyQt5中的信号与槽,js 与 Qt 对象之间互相调用

    一.PyQt中的信号与槽 信号(Signal)和槽(Slot)是Qt中的核心机制,用在对象之间互相通信.在Qt中每个QObject对象和PyQt中所有继承自QWidget的控件(这些都是QObject ...

  7. 五、Pyqt5事件、信号和槽

    PyQt中提供了两种针对事件处理的机制:一种是事件,另一种则是信号和槽. 一.事件 事件处理在PyQt中是比较底层的,常用的事件有键盘事件.鼠标事件.拖放事件.滚轮事件.定时事件.焦点事件.进入和离开 ...

  8. PyQt5(3)——信号和槽初探

    信号和槽是QT的核心机制(当信号发射时,链接的槽函数会自动执行) 在pyqt5中信号和槽通过 QObject.signal.connect()链接. QObject类或子类(QWidget)派生的类都 ...

  9. PyQt5信号-槽机制

    signal -> emit -> slot signal.connect(slot) signal.disconnect(slot) 信号 (singal) 可以连接无数多个槽 (slo ...

  10. PyQT5:信号和槽

    PyQT5:信号和槽 信号和槽 Qt的主要特征之一是它使用信号和插槽在对象之间进行通信. 当潜在的事件发生时,会发出一个信号.插槽是可调用的Python,如果将信号连接到插槽,则在发出信号时将调用该插 ...

随机推荐

  1. 安装mangodb

    1.配置yum源 [root@www ~]# cat /etc/yum.repos.d/mongodb-org-3.4.repo [mongodb-org-3.4] name=MongoDB Repo ...

  2. 1 Java基础知识

    1)面向对象的特性有哪些? 答:封装.继承和多态. 2)Java 中覆盖(Override)和重载(Overload)是什么意思? 答:覆盖是指子类对父类方法的一种重写,只能比父类抛出更少的异常,访问 ...

  3. 【VS开发】VS2013多字节工程问题uilding an MFC project for a non-Unicode character set is deprecated

    VS2013多字节工程问题 使用VS2013编译旧版VC++程序时,提示Building an MFC project for a non-Unicode character set is depre ...

  4. JS ----- 底层原理

    什么是JS JavaScript是一种基于对象的动态.弱类型脚本语言(简称JS),是一种解释型语言,和其他的编程语言不同,如java/C++等编译型语言,这些语言在代码执行前会进行通篇编译,先编译成字 ...

  5. 网站换VPS wdcp操作记录

    http://www.wdlinux.cn/bbs/thread-2795-1-1.html 分种情况1 从别的环境迁移到wdcp的环境2 从老的wdcp迁移到新的wdcp环境 对于第一个,没有较好的 ...

  6. Angular5 *ngIf 和 hidden 的区别

    问题 项目中遇到一个问题,有一个过滤查询的面板,需要通过一个展开折叠的button,来控制它的show 和 hide.这个面板中,有一个Select 组件,一个 input 查询输入框. 原来代码是: ...

  7. 利用三层交换机实现VLAN间路由

    利用三层交换机实现VLAN间路由 本实验模拟企业网络场景.公司有两个部门一销 售部和客服部,分别规划使用VLAN 10和VLAN 20.其中销售部下有两台终端PC-1和PC-2,客服部下有一台终端PC ...

  8. Editor placeholder in source code错误

    When you insert code via autocompletion (or via a code snippet, sometimes), there may be placeholder ...

  9. [转帖].NET Core单文件发布静态编译AOT CoreRT

    .NET Core单文件发布静态编译AOT CoreRT https://www.cnblogs.com/linezero/p/CoreRT.htm .NET Core单文件发布静态编译AOT Cor ...

  10. Spring(九)--通知

    Spring之Advice通知 Spring原生的经典模式  实现AOPadvice :通知 前置通知:在目标方法执行之前执行!不能改变方法的执行流程和结果!            实现MethodB ...