当前位置: 首页 > ai >正文

【Qt开发】信号与槽

目录

1,信号与槽的介绍

2,信号与槽的运用

3,自定义信号


1,信号与槽的介绍

        在Qt框架中,信号与槽机制是一种用于对象间通信的强大工具。它是在Qt中实现事件处理和回调函数的主要方法。

  • 信号:窗口中,当某个事件发生时,一个类可能会发出一个信号。例如,按钮被点击、窗口被关闭等。信号是自动触发的,无需用户干预,它的本质就是事件。

  • :槽是用来接收并处理信号的函数。槽函数执行特定的操作来响应接收到的信号。简单来说,对信号做出的响应动作就称之为槽。通常,会将槽与信号关联起来,以便处理。槽的本质是一种回调函数,在Qt5以及更高版本中,槽函数与普通函数基本没啥区别。

        在Qt中,用户和控件的每次交互过程称为一个事件。比如 “用户点击按钮” 是⼀个事件,“用户关闭窗口” 也是⼀个事件。每个事件都会发出一个信号,信号发出后将会进行槽处理,例如用户点击按钮会发出 “按钮被点击” 的信号,用户关闭窗口会发出 “窗口被关闭” 的信号,然后接收该信号的槽将会执行对应的处理函数。

2,信号与槽的运用

认识QObject:

        QWidget是 Qt 框架中的一个核心基类,主要用于实现对象间的通信机制(如信号与槽机制),并提供基础的对象管理功能,如事件处理、几何坐标管理、内置信号和槽等,这一点通过Qt的不断学习我们会诼渐认识到。

        Qt系统中提供的类本身是存在一定的继承关系。如QPushButton、QLineEdit、QTextEdit、QLabel等,它们都有共同的父类,即QWidget,它是一个控件,也就是图形化界面中的小部件。QWidget还有一个父类——QObject。可以说所有的事务类都继承QObject。

        在Qt中,每个继承自QWidget(或者更准确地说,继承自QObject)的部件(Widget)都内置了一系列预定义的信号和槽,例如,QPushButton有一个clicked()信号,当按钮被点击时会发出这个信号。

认识connect函数:

        在 Qt 中,QObject 类提供了一个静态成员函数 connect(),该函数用于连接信号和槽。

函数格式:

        形式 一:connect(const QObject *sender,

                                                const char *signal,

                                                const QObject *receiver,

                                                const char *method,

                                                Qt::ConnectionType type = Qt::AutoConnection)

​​​​​​​        形式二:connect(const QObject* sender,

                                     const QMetaMethod& signal,
                                     const QObject* receiver,

                                     const QMetaMethod& method,
                                     Qt::ConnectionType type = Qt::AutoConnection);

参数说明:​​​​​​​

        sender:发出信号的对象。

        signal:要连接的信号。

        receiver:接收信号并处理它的对象。

        method:槽,即响应信号的方法。

        type:用于指定关联方式,暂时先不做考虑。

        形式二中第二个参数和第四个参数使用函数指针代替字符串来指定信号和槽,使编译器在编译期检查信号和槽的签名是否兼容,从而减少运行时错误。

connect运用样例:

    QPushButton* pushButton = new QPushButton(this);
    pushButton->setText("Qt");
    connect(pushButton, &QPushButton::clicked, this, &Widget::handleClick);

    槽函数的定义:

    void Widget::handleClick()
    {
        if (pushButton->text() == QString("Qt")) {
            pushButton->setText("Hello Qt");
        }
        else {
            pushButton->setText("Qt");
        }
    }

        注意:通过图形化界面生成的信号与槽机制(.ui文件进行操作)时,槽函数的名称不能随意更改,因为 .ui 文件内部专门生成的槽函数名来连接信号的,若是修改了函数名,它将不能正常连接。

3,自定义信号

        自定义信号在实际开发中很少遇到,因为内置的信号基本包含了用户的事件相关操作。这里知道即可。

        信号是一种特殊的函数机制,它的返回值必须是void,参数可有可无。这个函数的定义是 Qt 在编译过程中自动生成的,因此,自定义信号只需写出函数声明,并告诉 Qt 这是一个 “信号” 即可。

        自定义信号的运用需要使用 signals(自定义信号的标志)和 emit(发送信号)关键字。内置信号不需要手动触发(也可以使用emit发送,改变触发模式),用户在 GUI 进行相关操作时,就会自动触发信号。发送信号的代码已经内置到 Qt 框架中了。

样例:

      widget.h文件里的Widget类中添加以下代码:

              signals:
                      void mySignal(const QString&);  // 自定义信号mySignal()
                      void handleMySignal(const QString&); // 槽函数

      在widget.cpp文件中添加以下代码:

               // 连接信号与槽

              connect(this, &Widget::mySignal, this, &Widget::handleMySignal);
              // 发送出自定义的信号,类似内置信号中用户点击按钮然后自动发送信号。
              emit mySignal("处理自定义信号");// 发送信号的操作是根据用户操作的情况进行的
            void Widget::handleMySignal(const QString& text)// 参数text="处理自定义信号"
            {
                this->setWindowTitle(text);
            }

        注意:Qt5及更高的版本中,不加 emit 也能发送信号,但建议还是加上,使代码可读性更高。自定义信号的参数可以比槽函数的参数数量多,但参数之间的类型必须一样,且槽函数的参数不能比信号的参数多。因为一个槽函数可以绑定多个信号,若严格要求参数个数一致,就意味着信号绑定到槽函数的要求就变高了,而这样设置是为了使更多的信号绑定到一个槽函数上。

http://www.xdnf.cn/news/5899.html

相关文章:

  • 【技术追踪】InverseSR:使用潜在扩散模型进行三维脑部 MRI 超分辨率重建(MICCAI-2023)
  • Ansible安装与核心模块实战指南
  • 如何正确地写出单例模式
  • 嵌入式软件--stm32 DAY7 I2C通讯上
  • 码蹄集——分解、数组最大公约数、孪生质数、卡罗尔数、阶乘数
  • PY32系列单片机离线烧录器,可配置选项字节和上机台批量烧录
  • The Deep Learning Compiler: A Comprehensive Survey (深度学习编译器:全面调查)
  • milvus+flask山寨《从零构建向量数据库》第7章case2
  • FPGA图像处理(六)------ 图像腐蚀and图像膨胀
  • 【图像处理基石】遥感图像分析入门
  • stm32f103rct6中使用串口1 DMA通信程序含异常处理
  • 数据验证库pydantic的用法
  • 力扣热题——统计平衡排列的数目
  • 进程间通信分类
  • 数组练习题
  • 采购流程规范化如何实现?日事清流程自动化助力需求、采购、财务高效协作
  • 动态查找滚动容器(通用方案)
  • 故障诊断模型评估——混淆矩阵,如何使样本量一致(上)
  • 深入浅出之STL源码分析8_三个指针
  • PostgreSQL 恢复信息函数
  • Android Exoplayer多路不同时长音视频混合播放
  • window 显示驱动开发-报告图形内存(一)
  • ElasticSeach快速上手笔记-入门篇
  • VScode 的插件本地更改后怎么生效
  • 嵌入式学习--江协51单片机day5
  • React百日学习计划——Deepseek版
  • 销量预测评估指标
  • 【工作记录】Kong Gateway 入门篇之部署及简单测试
  • mpegts.js 播放flv视频报错:PIPELINE_ERROR_DECODE: video decode error!
  • FlashInfer - 安装