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. 自动驾驶分级标准 国际自动机工程师学会(SAE International)定义了六个级别的自动驾驶等级,从L0到L5[^1]。其中,L3及以上级别需要安全员具备更高的应急处理能力。 #### 2. 车辆感知系统的组成与功能 智能网联车通常配备多种传感器,如激光雷达、毫米波雷达、摄像头和超声波传感器等。这些设备协同工作以实现环境感知、障碍物检测等功能[^2]。 #### 3. 数据通信与网络安全 智能网联车依赖V2X(Vehicle-to-Everything)技术进行数据交换,在此过程中需防范潜在的网络攻击风险,例如中间人攻击或恶意软件入侵[^3]。 #### 4. 法律法规要求 不同国家和地区对于无人驾驶测试及运营有着严格的规定,考生应熟悉当地交通法典中有关自动化驾驶部分的具体条款[^4]。 ```python # 示例代码:模拟简单决策逻辑 def decide_action(sensor_data): if sensor_data['obstacle'] and not sensor_data['emergency']: return 'slow_down' elif sensor_data['pedestrian_crossing']: return 'stop_and_yield' else: return 'continue_driving' example_input = {'obstacle': True, 'emergency': False, 'pedestrian_crossing': False} action = decide_action(example_input) print(f"Action to take: {action}") ``` 需要注意的是,“橙点同学”作为特定平台上的学习资源名称,并不提供官方认证的标准答案集;建议通过正规渠道获取教材并参加培训课程来准备此类资格认证考试。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值