【Qt-20】Qt信号与槽

一、什么是信号和槽
信号是特定情况下被发射的事件,发射信号使用emit关键字,定义信号使用signals关键字,在signals前面不能使用public、private、protected等限定符,信号只用声明,不需也不能对其进行定义实现。另外,信号没有返回值,只能是void类型。
例:

发射信号:

emit dlgReturn(value);

 定义信号:

signals:
    void dlgReturn(int);  

槽是对信号响应的函数,使用slots关键字,槽可以是private、public、protected类型。
例:

private slots:
    void showValue(int value);

二、信号与槽的关联
例:
connect(dlg,SIGNAL(dlgReturn(int)),this,SLOT(showValue(int)));
第一个参数为发送信号的对象;第二个参数是要发送的信号;第三个参数是接收信号的对象;第四个参数是要执行的槽。connect()函数的返回值是bool类型。另外,在调用这个函数时信号和槽的参数只能有类型,不能有变量,若写成SLOT(showValue(int value))是错误的。
三、示例程序
实现效果:在主界面(widget.cpp)中创建一个对话框(mydialog.cpp),当点击对话框中确定按钮时,将输入的数值通过信号发射出去,主界面接收该信号,并显示数据。

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();

private:
    Ui::Widget *ui;

private slots:
	void showValue(int value);

};
#endif // WIDGET_H

widget.cpp

#include "widget.h"
#include "ui_widget.h"
#include "mydialog.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

	MyDialog *dlg = new MyDialog(this);
	// 将对话框中的自定义信号与主界面中的自定义槽进行关联
	connect(dlg, SIGNAL(dlgReturn(int)), this, SLOT(showValue(int)));
	dlg->show();
}

Widget::~Widget()
{
    delete ui;
}

void Widget::showValue(int value)         // 自定义槽
{
	ui->textEdit->append(QString::number(value));
}

mydialog.h

#ifndef MYDIALOG_H
#define MYDIALOG_H

#include <QDialog>

namespace Ui {
class MyDialog;
}

class MyDialog : public QDialog
{
    Q_OBJECT

public:
    explicit MyDialog(QWidget *parent = nullptr);
    ~MyDialog();

private:
    Ui::MyDialog *ui;

signals:
	void dlgReturn(int);                  // 自定义的信号


private slots:
	void on_pushButton_clicked();

};



#endif // MYDIALOG_H

mydialog.cpp

#include "mydialog.h"
#include "ui_mydialog.h"

MyDialog::MyDialog(QWidget *parent) :
    QDialog(parent),
    ui(new Ui::MyDialog)
{
    ui->setupUi(this);

}

MyDialog::~MyDialog()
{
    delete ui;
}


void MyDialog::on_pushButton_clicked()   // 确定按钮
{
	int value = ui->lineEdit->text().toInt();    // 获取输入的数值
	emit dlgReturn(value);               // 发射信号
	close();                             // 关闭对话框
}

运行结果:

四、发送自定义结构体信号

发送信号头文件

typedef struct TEST
{
	int data;
	int data2;
}test; //test结构变量,具有data、data2的属性
Q_DECLARE_METATYPE(TEST);

...

signals:
	void sgnParams(QVariant);

 发送信号cpp文件

TEST test;
test.data = 3;
test.data2 = 1;
QVariant var;
var.setValue(test);
emit sgnParams(var);

连接槽函数

connect(exportp, SIGNAL(sgnParams(QVariant)), this, SLOT(openSilo(QVariant)));

void VGRibbonWindow::openSilo(QVariant var)
{
    TEST d = var.value<test>();
	qDebug() << d.data;
	qDebug() << d.data2;
}

头文件

void openSilo(QVariant var);

五、发送QList信号

发送信号头文件

signals:
	void sgnParams(QList<int>);

 发送信号cpp文件

QList<int> num;
num.append(3);
num.append(1);
emit sgnParams(num);

连接槽函数

connect(exportp, SIGNAL(sgnParams(QList<int>)), this, SLOT(openSilo(QList<int>)));

void VGRibbonWindow::openSilo(QList<int> var)
{
   	for (int i = 0; i < var.size(); i++)
	{
		qDebug() << var.at(i);
	}
}

头文件

void openSilo(QList<int> var);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值