几种QQuickWidget与Qml交互数据的方法

QQuickWidget底层继承的是QWidget,但它可以加载Qml文件(组件),但我们有时候需要和Qml文件(组件)数据交互使用,本文介绍几种QQuickWidget与Qml交互数据的方法。

通过设置上下文属性

setContextProperty可以将变量设置到Qml环境中。

C++代码:

javascript 复制代码
QQuickWidget *view = new QQuickWidget;
QString str = "Hello world";
/* 设置变量到Qml中 */
view->rootContext()->setContextProperty("str", str);
view->setSource(QUrl("qrc:/View.qml"));
view->show();

Qml代码:

javascript 复制代码
import QtQuick 2.0
Rectangle {
    width: 640; height: 320
 
    Text {
        anchors.centerIn: parent;
        text: str  /* 引用C++传入的str变量。*/
    }
}

2.通过注册Qml类型方式

使用qmlRegisterType注册一个QObject派生类到Qml中。

C++代码:

javascript 复制代码
导入MyObject类到Qml中 */
qmlRegisterType<MyObject>("MyModel", 1, 0, "MyObject");
 
QQuickWidget *view = new QQuickWidget;
view->setSource(QUrl("qrc:/View.qml"));
view->show();

/*

「注意:导入的类型必须实例化才能使用」。

Qml代码:

javascript 复制代码
import QtQuick 2.0
/* 导入MyModel模块 */
import MyModel 1.0
 
Rectangle {
    width: 640; height: 320
 
    /* 使用MyModel模块的MyObject对象 */
    MyObject {
        id: myObject
        /* 设置text属性 */
        text: "12345"
        /* 读取打印text属性 */
        Component.onCompleted: console.log(text)
    }
}

3.通过调用Qml函数的方式

使用invokeMethod可以调用Qml中的函数。通过设置Qml的实例,函数名字,输入参数和返回值即可调用Qml中的函数。

C++代码:

javascript 复制代码
QQuickWidget *view = new QQuickWidget;
view->setSource(QUrl("qrc:/View.qml"));
 
QVariant retVal;
QMetaObject::invokeMethod(view->rootObject(), /* Qml实例 */
                          "execute",         /* 函数名字 */
                          Qt::DirectConnection, /* 连接方式 */
                          Q_RETURN_ARG(QVariant, retVal), /* 标记返回值 */
                          Q_ARG(QVariant, "Hello"), /* 输入参数1 */
                          Q_ARG(QVariant, "world"));/* 输入参数2 */
qDebug() << "value: " << retVal;
view->show();

Qml代码:

javascript 复制代码
import QtQuick 2.0
import MyModel 1.0
 
Rectangle {
    width: 640; height: 320
    
    /* Qml函数,注意是在顶级控件下定义 */
    function execute(var1, var2) {
        console.log(var1, var2)
        return true;
    }
}
相关推荐
Ricardo于18 天前
★3.3 事件处理
qml
梦起丶18 天前
Qml 中实现时间轴组件
qt·ui·时间轴·控件·qml
梦起丶19 天前
Qml 中实现任意角为圆角的矩形
qt·ui·控件·qml
码农客栈19 天前
qml XmlListModel详解
qml
小灰灰搞电子22 天前
QML states和transitions的使用
qt·qml
码农客栈23 天前
qml SpringAnimation详解
qml
人才程序员1 个月前
Windows11 安卓子系统存储位置更改
android·c语言·c++·qt·qml·界面
瀛洲客1 个月前
Qt6 QML RegularExpressionValidator 输入中文的坑
qt·qml·中文·汉字输入
梦起丶1 个月前
Qml 中实现毛玻璃效果
qt·ui·qml·毛玻璃