首先要說明的是,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
通過QDeclarativeEngine和QDeclarativeComponent先獲得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的函數