Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1069639
  • 博文数量: 264
  • 博客积分: 6005
  • 博客等级: 大校
  • 技术积分: 2798
  • 用 户 组: 普通用户
  • 注册时间: 2007-08-08 20:15
文章分类

全部博文(264)

文章存档

2011年(42)

2010年(213)

2009年(4)

2008年(2)

2007年(3)

分类:

2010-10-14 22:28:46


Overview

This snippet shows how to connect signals and slots between Qt and QML code.

Signals and slots are one way to provide data for the Qt Quick UI and make the UI react to changes in the model.

Preconditions

  • Qt 4.7 or higher is installed on your platform.

Source

NOTE: The parameter type in signal and slot is QVariant on the C++ side, as the functions in QML are JavaScript and they have no type.

myclass.h

#ifndef MYCLASS_H
#define MYCLASS_H
 
#include
#include
 
class MyClass : public QObject
{
Q_OBJECT
 
public:
MyClass() {}
 
public slots:
void getData() {
QString text("New data");
emit data(QVariant(text));
}
 
signals:
void data(QVariant data);
};
 
#endif // MYCLASS_H

main.cpp

#include 
#include
#include
#include
 
int main(int argc, char *argv[])
{
QApplication app(argc, argv);
 
MyClass myClass;
 
QDeclarativeView view;
view.setSource(QUrl("./ui.qml"));
view.setResizeMode(QDeclarativeView::SizeRootObjectToView);
 
QObject *rootObject = dynamic_cast<QObject*>(view.rootObject());
 
QObject::connect(rootObject, SIGNAL(dataRequired()), &myClass, SLOT(getData()));
QObject::connect(&myClass, SIGNAL(data(QVariant)), rootObject, SLOT(updateData(QVariant)));
 
#if defined(Q_WS_MAEMO_5)
view.setGeometry(QRect(0,0,800,480));
view.showFullScreen();
#elif defined(Q_WS_S60)
view.setGeometry(QRect(0,0,640,360));
view.showFullScreen();
#else
view.setGeometry(QRect(100,100,800, 480));
view.show();
#endif
 
return app.exec();
}

ui.qml

// ui.qml
import Qt 4.7
 
Rectangle {
signal dataRequired;
 
function updateData(text) { dataText.text = text } // slot
 
anchors.fill: parent; color: "black"
 
Text {
id: dataText
anchors.centerIn: parent; color: "white"
}
 
MouseArea {
anchors.fill: parent
onClicked: dataRequired()
}
}

Postconditions

The signals and slots in both Qt and QML are connected to each other: when rootObject's dataRequired is signalled, myClass's getData gets called. Also, when myClass data is signalled, rootObject's updateData is called.


阅读(1777) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~