当前位置: 首页 > article >正文

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

QQuickWidget底层继承的是QWidget,但它可以加载Qml文件(组件),但我们有时候需要和Qml文件(组件)数据交互使用,本文介绍几种QQuickWidget与Qml交互数据的方法。
1.
通过设置上下文属性
setContextProperty可以将变量设置到Qml环境中。

C++代码:

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

Qml代码:

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

2.通过注册Qml类型方式
  使用qmlRegisterType注册一个QObject派生类到Qml中。

C++代码:

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

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

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++代码:

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代码:

import QtQuick 2.0
import MyModel 1.0
 
Rectangle {
    width: 640; height: 320
    
    /* Qml函数,注意是在顶级控件下定义 */
    function execute(var1, var2) {
        console.log(var1, var2)
        return true;
    }
}

http://www.kler.cn/a/388549.html

相关文章:

  • 【MySQL从入门到放弃】InnoDB磁盘结构(一)
  • Vim9 语法高亮syntax 在指定的缓冲区和窗口执行命令
  • 实战指南:理解 ThreadLocal 原理并用于Java 多线程上下文管理
  • 【Python】爬虫通过验证码
  • java操作ES(一)RestHighLevelClient(2)集成与demo
  • 管家婆财贸ERP BB045.销售批量收款
  • 深入理解 Git 及其工具的用途、使用方法与区别
  • 项目功能--会员数量折线图
  • 【计网不挂科】计算机网络期末考试(综合)——【选择题&填空题&判断题&简述题】完整试卷
  • EPLAN商业版与教育版的功能区别有多大
  • 「QT」几何数据类 之 QPoint 整型点类
  • 学习日记_20241110_聚类方法(K-Means)
  • MatSci-LLM ——潜力和挑战以及大规模语言模型在材料科学中的应用
  • 手机上用什么方法可以切换ip
  • 设计模式之建造者模式(各项装修物料组合套餐选配场景)
  • 边缘的检测
  • ssh中公钥和私钥是具体作用,以及通俗解释
  • JavaSecLab靶场搭建
  • JavaWeb:文件上传1
  • (Go基础)变量与常量?字面量与变量的较量!
  • 微信小程序官方评价组件wxacommentplugin下线后如何巧妙调用
  • 【网络原理】关于HTTP状态码以及请求的构造的哪些事
  • 扁平化在APP设计领域成了过眼云烟,3D拟物化又开始回归了。
  • WPF中的依赖属性
  • 「QT」几何数据类 之 QSizeF 浮点型尺寸类
  • 14、NAT和桥接区别