时间:2021-12-03 09:27:09 | 栏目:C代码 | 点击:次
信号槽是 Qt 框架引以为豪的机制之一。当用户触发某个事件时,就会发出一个信号(signal),这种发出是没有目的的,类似广播。如果有对象对这个信号感兴趣,它就会连接(connect)绑定一个函数(称为槽slot)来处理这个信号。也就是说当信号发出时,被连接的槽函数会自动被回调。这有点类似与开发模式中的观察者模式,即当发生了感兴趣的事件,某一个操作就会被自动触发
信号和槽是Qt特有的信息传输机制,是Qt设计程序的重要基础,它可以让互不干扰的对象建立一种联系。槽的本质是类的成员函数,其参数可以是任意类型的。和普通C++成员函数几乎没有区别,它可以是虚函数,也可以被重载。可以是公有的、保护的、私有的、也可以被其他C++成员函数调用。唯一区别的是:槽可以与信号连接在一起,每当和槽连接的信号被发射的时候,就会调用这个槽
connect 函数原型如下:
[static] QMetaObject::Connection QObject::connect(const QObject *sender, const char *signal, const QObject *receiver, const char *method, Qt::ConnectionType type = Qt::AutoConnection)
ConnectionType 是一个定义在 Qt namespace 中的一个枚举,具体内容如下:
enum ConnectionType { AutoConnection, DirectConnection, QueuedConnection, BlockingQueuedConnection, UniqueConnection = 0x80 };
C++ 连接信号槽 - Qt4 语法
connect(ui->pushButton, SIGNAL(clicked()), this, SLOT(close()));
C++ 连接信号槽 - Qt5 语法
connect(ui->pushButton, &QPushButton::clicked, this, &MainWindow::close)
C++ 连接信号槽 - 函数指针
void(MainWindow:: *buttonClickSlot)() = &MainWindow::onButtonPushed; connect(ui->pushButton, &QPushButton::clicked, this, buttonClickSlot);
C++ 连接信号槽 - Lambda 表达式
connect(ui->pushButton, &QPushButton::clicked, this, [=](){ this->close(); });
C++ 信号连接 QML 的槽
class Test { signals: void sendData(QString str); }
1)如果注册的是全局对象,则需要使用 Connections 连接:
Connections { target: test onSendData: { console.log(str) } }
2)如果注册的是类,则需要先实例化对象,之后直接使用 on 接收:
Test { onSendData: { console.log(str) } }
QML 信号连接 C++ 的槽
#include <QQuickItem> QObject *quitButton = root->findChild<QObject*>("quitButton"); if (quitButton) { QObject::connect(quitButton, SIGNAL(clicked()), &app, SLOT(quit())); }
C++ 调用 QML 函数
QObject *changeBtn = root->findChild<QObject*>("objectName"); if (changeBtn) { QMetaObject::invokeMethod(changeBtn, "changeColor"); }
QML 调用 C++ 函数
onClicked: { className.test(); }
QML 信号连接 QML 的槽
// A.qml Rectangle { signal sendData(var data) } // B.qml Rectangle { onSendData: console.log(data) }