PyQt5第六部分-信号,槽函数与事件

0 前言

>>返回Python系列文章目录<<

1 传递信号

内置信号使用connect连接槽函数

1.1 常见内置信号

鼠标点击信号说明
self.clicked.connect(fun)单击信号,传递self
self.toggled.connect(fun)触发信号,传递self
self.itemClicked.connect(fun)单击条目信号,传递(self, item)
self.itemDoubleClicked.connect(fun)双击条目信号,传递(self, item)
self.currentIndexChanged.connect(fun)选中条目信号,传递(self, idx)
右键菜单信号说明
self.setContextMenuPolicy()右键菜单功能:
Qt.DefaultContextMenu: 默认菜单,重写contextMenuEvent()实现自定义
Qt.NoContextMenu: 无菜单,事件响应传递给部件父级
Qt.PreventContextMenu: 无菜单,事件响应不继续传递
Qt.ActionsContextMenu: 事件菜单,只响应部件事件,部件子件的事件不响应
Qt.CustomContextMenu: 用户自定义菜单,需绑定事件customContextMenuRequested,并实现 槽函数
内容变化信号说明
self.editingFinished.connect(fun)编辑完成信号,传递self
self.textChanged.connect(fun)文本变更信号,传递self
线程变化信号说明
self.started.connect(fun)线程开始信号,传递self
self.finished.connect(fun)线程结束信号,传递self

1.2 将所有子构建都作为self的属性,利用信号默认的self传递所有数据

import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *

class MyWindow(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.move(500, 400)
        self.setFixedSize(300, 200)
        vlayout = QVBoxLayout()
        self.setLayout(vlayout)

        self.label = QLabel('关闭')
        self.label.setAlignment(Qt.AlignCenter)
        vlayout.addWidget(self.label)

        self.btn = QPushButton('开关')
        self.btn.clicked.connect(self.labelSwitch)  # 信号
        vlayout.addWidget(self.btn)

    def labelSwitch(self):  # 槽函数
        self.label.setText(self.btn.text())

if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = MyWindow()
    window.show()
    sys.exit(app.exec_())

在这里插入图片描述

2.3 使用lambda函数传递所需要的数据

import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *

class MyWindow(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.move(500, 400)
        self.setFixedSize(300, 200)
        vlayout = QVBoxLayout()
        self.setLayout(vlayout)

        label = QLabel('关闭')
        label.setAlignment(Qt.AlignCenter)
        vlayout.addWidget(label)

        btn = QPushButton('开关')
        btn.clicked.connect(lambda: self.labelSwitch(btn, label))  # 信号
        vlayout.addWidget(btn)

    def labelSwitch(self, btn, label):  # 槽函数
        label.setText(btn.text())

if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = MyWindow()
    window.show()
    sys.exit(app.exec_())

2.4 信号的发送者可以通过self.sender()方法获得

import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *


class MyWindow(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.move(500, 400)
        self.setFixedSize(300, 200)
        vlayout = QVBoxLayout()
        self.setLayout(vlayout)

        label = QLabel('关闭')
        label.setAlignment(Qt.AlignCenter)
        vlayout.addWidget(label)

        btn = QPushButton('开关')
        btn.clicked.connect(lambda: self.labelSwitch(label))  # 信号
        vlayout.addWidget(btn)

    def labelSwitch(self, label):  # 槽函数
        btn = self.sender()
        label.setText(btn.text())

if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = MyWindow()
    window.show()
    sys.exit(app.exec_())

2 事件处理

控件既可以主动发送信号,也可以被动的等待事件

事件必须写在要触发事件的构建类定义里

事件的函数名已经写好,只能重构,不可变更,常见的事件如下:

2.1 鼠标事件

def mousePressEvent(self, event)
def mouseReleaseEvent(self, event)
def mouseDoubleClickEvent(self, event): 
def mouseMoveEvent(self, event)

event参数是QMouseEvent对象,有以下常用方法:

QMouseEvent类说明
self.pos()返回QPoint类
self.button()返回触发对象,在PyQt5.QtCore中:
Qt.NoButton: 没有按下鼠标键
Qt.LeftButton: 按下鼠标左键
Qt.RightButton: 按下鼠标右键
Qt.MiddleButton: 按下鼠标中键
self.buttons()返回前面所列枚举值的组合,用于判断同时按下了哪些键
self.modifiers()判断按下了哪些修饰键
Key_Control, Key_Shift, Key_Alt

案例:

def mouseReleaseEvent(self, event):
    # 单击左键
    if event.button() == Qt.LeftButton:
        print("单击鼠标左键的事件: 自己定义")
        
    # 单击右键
    if event.button() == Qt.RightButton:
        print("单击鼠标右键的事件: 自己定义")

def mouseDoubleClickEvent(self, event): 
    # 双击左键
    if event.button() == Qt.LeftButton:
        print ("鼠标双击事件: 自己定义")

2.2 右键菜单事件

setContextMenuPolicy(Qt.DefaultContextMenu) # 启用默认右键菜单

def contextMenuEvent(self, event): # 重写事件

event参数是QContextMenyEvent对象,有以下常用方法:

QKeyEvent类说明
self.pos()返回QPoint类

2.3 键盘事件

def keyPressEvent(self,event)

event参数是QKeyEvent对象,有以下常用方法:

QKeyEvent类说明
self.key()获取按键对应的Qt常量值
Key_0-Key_9Key_A-Key_ZKey_F1-Key_F35, Key_CapsLock, Key_Tab
Key_Enter, Key_Return, Key_Backspace, Key_Space, Key_Shift, Key_Control
Key_Alt, Key_Up, Key_Down, Key_Left, Key_Right,

2.4 离开事件

def closeEvent(self, event):

event参数是QCloseEvent对象,有以下常用方法:

QCloseEvent类说明
self.accept()关闭窗口
self.ignore()放弃关闭窗口

2.5 拖曳事件

self.setAcceptDrops(True)  # 启用拖曳事件

def dragEnterEvent(self, event):  # 必须先进入这个时间,选择accept或ignore该拖曳操作
def dragMoveEvent(self, event):   # 在拖曳操作进行时会触发该事件
def dragLeaveEvent(self, event):  # 当执行一个拖曳操作,并且鼠标指针离开该控件时,这个事件被触发
def DropEvent(self, event):       # 当拖曳操作在其目标控件上被释放时,这个事件将被触发

event参数是QDropEvent对象,有以下常用方法:

QDropEvent类说明
self.accept()接受拖曳事件
self.ignore()拒绝拖曳事件
=self.mimeData()返回QMimeData类
QMimeData类说明
=self.hasText()判读是否具有text信息,输出TrueFalse
=self.text()读取text信息
=self.hasHtml()判读是否具有html信息,输出TrueFalse
=self.html()读取html信息
=self.hasUrls()判读是否具有urls信息,输出TrueFalse
=self.urls()读取urls信息,为文件path列表
=self.hasImage()判读是否具有image信息,输出TrueFalse
=self.imageData()读取image信息

2.6 实例 单击,右击和离开事件

import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *

class MyWindow(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.move(500, 400)
        self.setFixedSize(300, 200)
        vlayout = QVBoxLayout()
        self.setLayout(vlayout)
        label = MyLabel()
        vlayout.addWidget(label)
        btn = MyPushButton()
        vlayout.addWidget(btn)

    def closeEvent(self, event):  # 关闭事件
        reply = QMessageBox.question(self, '本程序', "是否要退出程序?", QMessageBox.Yes | QMessageBox.No)
        if reply == QMessageBox.Yes:
            event.accept()
        else:
            event.ignore()

class MyLabel(QLabel):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setText('关闭')
        self.setAlignment(Qt.AlignCenter)
        self.setContextMenuPolicy(Qt.DefaultContextMenu)  # 打开右键菜单的策略

    def contextMenuEvent(self, event):
        menu = QMenu(self)
        openFile = menu.addAction('打开文件')
        openDir = menu.addAction('打开文件夹')
        action = menu.exec_(self.mapToGlobal(event.pos()))
        if action == openFile:
            print('打开文件')
        if action == openDir:
            print('打开文件夹')

class MyPushButton(QPushButton):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setText('关闭')

    def mouseReleaseEvent(self, event):  # 鼠标左击事件
        if event.button() == Qt.LeftButton:
            print('左击事件')
            if self.text() == '关闭':
                self.setText('关闭')
            else:
                self.setText('开启')

if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = MyWindow()
    window.show()
    sys.exit(app.exec_())

在这里插入图片描述
>>返回Python系列文章目录<<

  • 1
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: PyQt5Python编程语言的一种GUI库,用于创建桌面应用程序。它是由Riverbank Computing开发的,为开发者提供了丰富的GUI元素和功能,使他们能够轻松地构建各种用户界面。 而PyQt5-sip是PyQt5的一部分,是一个用于生成Python绑定代码的代码生成器。它将C++头文件转换为Python模块,使开发者能够在Python中使用C++框架和库。PyQt5-sip负责将QObject、QEvent等类和对象转换为Python可调用的代码。 PyQt5PyQt5-sip之间的关系可以简单地理解为:PyQt5-sip是PyQt5的一个重要组成部分,它提供了与C++代码的交互能力,使得PyQt5能够与底层的Qt库进行通信。在安装PyQt5时,PyQt5-sip会自动包含在内,因此我们不需要单独安装或管理PyQt5-sip。 对于开发者而言,了解PyQt5PyQt5-sip的版本非常重要。这是因为PyQt5PyQt5-sip的版本必须相互兼容,以确保代码能够正确地运行。如果您使用的PyQt5版本与PyQt5-sip不兼容,可能导致一些错误或功能失效。因此,在使用PyQt5时,我们需要确保选择合适的PyQt5-sip版本与之配套。 总结来说,PyQt5是一款强大的GUI库,而PyQt5-sip是PyQt5的重要组成部分,用于生成与C++代码交互的Python绑定代码。了解并选择合适的PyQt5PyQt5-sip版本对于确保顺利开发和运行PyQt5应用程序是必要的。 ### 回答2: PyQt5PyQt5-sip 是两个与 Python 语言结合使用的库。这两个库的版本是相互关联的。 PyQt5 是基于 Qt 库的 Python 封装,可以用于开发图形界面应用程序。它提供了丰富的 GUI 组件和功能,可以通过 Python 代码来创建和控制界面。 PyQt5-sip 是 PyQt5 的依赖库,它是用于处理 Python 对象和 Qt 对象之间的转换和通信的工具。它实际上是 PyQt5 的一部分,负责生成包装 Qt 类的 Python 类的代码。 这两个库的版本是相关的,因为 PyQt5-sip 的版本必须与 PyQt5 的版本相匹配。如果版本不匹配,可能会导致库之间的不兼容性和错误。因此,在使用 PyQt5 时,你需要根据 PyQt5 的版本来选择相应的 PyQt5-sip 版本。 通常,你可以通过以下命令来安装最新版本的 PyQt5PyQt5-sip: ``` pip install PyQt5 ``` 然后,PyQt5-sip 会自动安装为 PyQt5 的依赖项。 总的来说,PyQt5PyQt5-sip 是用于 Python GUI 开发的重要工具。在使用时需要注意版本匹配,以确保两者能够正常工作。 ### 回答3: PyQt5是一个Python绑定的Qt库,它允许开发者通过Python语言来开发跨平台的图形用户界面(GUI)应用程序。 而pyqt5-sip是PyQt5的一个SIP模块,用于将C++库和Python语言进行交互。它是一个必需的依赖项,需要与PyQt5配套使用。 PyQt5-sip是由Riverbank Computing提供的一款工具,它通过SIP(一个Python/C++通信框架)来实现C++和Python的互操作性。SIP工具将C++代码转换成Python代码,使得开发人员可以在Python中直接调用C++代码和库。 在使用PyQt5时,我们需要安装和配置PyQt5pyqt5-sip两个软件包。PyQt5提供了丰富的Qt类和方法,用于创建各种类型的GUI应用程序。而pyqt5-sip则是在PyQt5中作为连接器的角色,它将C++对象转换为Python对象,并使得Python能够直接调用C++代码和库,实现了二者之间的桥梁。 需要注意的是,PyQt5pyqt5-sip的版本需要匹配,才能保证二者的兼容性。因此,在安装PyQt5pyqt5-sip时,应该选择合适的版本,并确保它们能够正确地配合使用。 总的来说,PyQt5是一个功能强大的库,用于开发Python GUI应用程序,而pyqt5-sip是其所依赖的一个模块,用于实现C++和Python之间的互操作性。它们共同工作,帮助我们使用Python语言开发出跨平台的GUI应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值