C++与QML交互的 三种方法对比

来源:互联网 发布:windows安装informix 编辑:程序博客网 时间:2024/04/29 22:37

首先要说明的是,C++只能使用被装载的(setSource) 的.qml 的信号和槽。以下方法皆遵循此原则:

方法一:对QML Object进行类型转换。

QDeclarativeView mainQMLView;
QDeclarativeItem *rootItem_p;
mainQMLView.setSource(QUrl("qrc:/MainQML.qml"));
rootItem_p = qobject_cast<QDeclarativeItem*>(mainQMLView.rootObject());QMetaObject::invokeMethod(rootItem_p,"progressChanged", Q_ARG(QVariant, 100));

此时rootItem_p代表就是qml对应的QDeclarativeItem,因此可以从rootItem_p中获得qml的信号和槽。

方法二:使用QMetaObject

通过QDeclarativeEngineQDeclarativeComponent先获得Object,在使用QMetaObject::invokeMethod()

QDeclarativeEngine engine;QDeclarativeContext *context = newQDeclarativeContext(engine.rootContext());
QDeclarativeComponent
 component(&engine, QUrl::fromLocalFile("main.qml"));
QObject
 *object = component.create(context);
QVariant
 str("Hello");
QMetaObject
::invokeMethod(object, "say", Q_ARG(QVariant, str));

优点:可以不显式就调用qml里面的函数;
缺点:只能是单向的,
qml没有办法调用qt里面的函数。

方法三:Qml调用Qt里面的函数

QDeclarativeView mainQMLView;
mainQMLView.rootContext()->setContextProperty("stbDVBCObject", &stbDVBCClass);

mainQMLView.setSource(QUrl("qrc:/MainQML.qml"));优点:能在qml里面直接使用mainwindow的对象L调用其函数缺点:不能调用qml的函数
原创粉丝点击