【QT】QT从零入门教程(三):信号与槽

在学了在学了! 2020-08-19 18:24:06 2401

信号与槽

信号和槽是QT中最基本的概念,也是QT中的核心机制。信号和槽是QT自行定义的一种通信机制,独立于标准的C/C++语言,因此要正确的处理信号和槽,必须借助moc(Meta Object Compiler)这一QT工具,该工具是个C++预处理程式,它为高层次的事件处理自动生成所需要的附加代码。

信号与槽可以实现多信号与单个槽的连接,也可以实现单信号与多个槽的连接,甚至能实现信号间的连接,这时第一个信号发射后,第二个信号也将被即时发射。如果单信号连接多个槽,当这个信号被发射时,与之相关的槽被激活的顺序将是随机的。

所有从QObject或其子类(例如Qwidget)派生的类都能够包含信号和槽。当对象改动其状态时,信号就由该对象发射(emit)出去,而槽则用于接收信号。

signals前面不可加public、private和protected进行修饰,它必须是void类型而且只声明不定义。slots前面可以加修饰,它作为普通的C++成员函数,能被正常调用。slots区域中的函数能有参数,但其参数不能有缺省值。 宏定义不能用在signal和slot的参数中。

1、当信号与槽函数的参数数量相同时,它们参数类型要完全一致。

  // 头文件
#include <QtWidgets/QMainWindow>
#include "ui_ImageProcessing.h"

class ImageProcessing : public QMainWindow
{
    Q_OBJECT

public:
    ImageProcessing(QWidget *parent = Q_NULLPTR);

private:
    Ui::ImageProcessingClass ui;

signals:
    void iSignal(int b);     // 信号

private slots:
    void iSlot(int b);       // 槽函数
};

// cpp
#include <QMainWindow>
#include <QtGui>
#include <QtWidgets>
#include "MainWindow.h"

ImageProcessing::ImageProcessing(QWidget *parent)
    : QMainWindow(parent)
{
    ui.setupUi(this);
    connect(this, SIGNAL(iSignal(int)), this, SLOT(iSlot(int)));  // 连接信号和槽函数
    emit iSignal(5);        // 发射信号
}

void ImageProcessing::iSlot(int b)     // 槽函数定义
{
    QString qString;
    qDebug() << qString.number(b);
}

2、当信号的参数与槽函数的参数数量不同时,只能是信号的参数数量多于槽函数的参数数量,且前面相同数量的参数类型应一致,信号中多余的参数会被忽略。

// 头文件
#include <QtWidgets/QMainWindow>
#include "ui_ImageProcessing.h"

class ImageProcessing : public QMainWindow
{
    Q_OBJECT

public:
    ImageProcessing(QWidget *parent = Q_NULLPTR);

private:
    Ui::ImageProcessingClass ui;

signals:
    void iSignal(int a,float b);   // 信号

private slots:
    void iSlot(int b);             // 槽函数
};

// cpp
#include <QMainWindow>
#include <QtGui>
#include <QtWidgets>
#include "MainWindow.h"

ImageProcessing::ImageProcessing(QWidget *parent)
    : QMainWindow(parent)
{
    ui.setupUi(this);
    connect(this, SIGNAL(iSignal(int,float)), this, SLOT(iSlot(int)));  // 连接信号和槽函数
    emit iSignal(1000, 0.3);    // 发射信号
} 

void ImageProcessing::iSlot(int b)    // 槽函数定义
{
    QString qString;
    qDebug() << qString.number(b);
}

3、在不进行参数传递时,信号槽绑定时也是要求信号的参数数量大于等于槽函数的参数数量。这种情况一般是一个带参数的信号去绑定一个无参数的槽函数。

// 头文件
#include <QtWidgets/QMainWindow>
#include "ui_ImageProcessing.h"

class ImageProcessing : public QMainWindow
{
    Q_OBJECT

public:
    ImageProcessing(QWidget *parent = Q_NULLPTR);

private:
    Ui::ImageProcessingClass ui;

signals:
    void iSignal(int a,float b);

private slots:
    void iSlot();
};
// cpp
#include <QMainWindow>
#include <QtGui>
#include <QtWidgets>
#include "MainWindow.h"

ImageProcessing::ImageProcessing(QWidget *parent)
    : QMainWindow(parent)
{
    ui.setupUi(this);
    connect(this, SIGNAL(iSignal(int,float)), this, SLOT(iSlot()));
    emit iSignal(1000, 0.3);
}

void ImageProcessing::iSlot()
{
    QString qString = " Qt test (signals & slots) ";
    qDebug() << qString;
}

断开连接

当信号与槽没有必要继续保持关联时,我们可以使用 disconnect 函数来断开连接。其定义如下,用于断开发射者中的信号与接收者中的槽函数之间的关联。

  bool QObject::disconnect(const QObject * sender, const char * signal, const Object * receiver, const char * member)

有三种情况必须使用 disconnect() 函数:

1、断开与某个对象相关联的任何对象。

在某个对象中可能定义了一个或者多个信号时,这些信号与另外若干个对象中的槽相关联,如果我们要切断这些关联,就可以利用这个方法,简洁有效。

  disconnect(myObject, 0, 0, 0) 

// myObject->disconnect()

2、断开与某个特定信号的任何关联

disconnect(myObject, SIGNAL(mySignal()), 0, 0) 

// myObject->disconnect(SIGNAL(mySignal()))

3、断开两个对象之间的关联。

disconnect(myObject, 0, myReceiver, 0) 

// myObject->disconnect(myReceiver)

在 disconnect 函数中 0 可以用作一个通配符,分别表示任何信号、任何接收对象、接收对象中的任何槽函数。但是发射者 sender 不能为 0,其它三个参数的值可以等于 0。

原帖:https://blog.csdn.net/u013165921/article/details/79281374

声明:本文内容由易百纳平台入驻作者撰写,文章观点仅代表作者本人,不代表易百纳立场。如有内容侵权或者其他问题,请联系本站进行删除。
红包 点赞 收藏 评论 打赏
评论
0个
内容存在敏感词
手气红包
    易百纳技术社区暂无数据
相关专栏
关于作者
在学了在学了!

在学了在学了!

人在车底,非常的菜。

原创104
阅读38.5w
收藏15
点赞10
评论4
打赏用户 0
我要创作
分享技术经验,可获取创作收益
分类专栏
置顶时间设置
结束时间
删除原因
  • 广告/SPAM
  • 恶意灌水
  • 违规内容
  • 文不对题
  • 重复发帖
打赏作者
易百纳技术社区
在学了在学了!
您的支持将鼓励我继续创作!
打赏金额:
¥1易百纳技术社区
¥5易百纳技术社区
¥10易百纳技术社区
¥50易百纳技术社区
¥100易百纳技术社区
支付方式:
微信支付
支付宝支付
易百纳技术社区微信支付
易百纳技术社区
打赏成功!

感谢您的打赏,如若您也想被打赏,可前往 发表专栏 哦~

举报反馈

举报类型

  • 内容涉黄/赌/毒
  • 内容侵权/抄袭
  • 政治相关
  • 涉嫌广告
  • 侮辱谩骂
  • 其他

详细说明

审核成功

发布时间设置
发布时间:
是否关联周任务-专栏模块

审核失败

失败原因
备注
拼手气红包 红包规则
祝福语
恭喜发财,大吉大利!
红包金额
红包最小金额不能低于5元
红包数量
红包数量范围10~50个
余额支付
当前余额:
可前往问答、专栏板块获取收益 去获取
取 消 确 定

小包子的红包

恭喜发财,大吉大利

已领取20/40,共1.6元 红包规则

    易百纳技术社区