C++访问QML控件-----QML访问C++对象属性和方法

C++访问QML控件

  • C++访问QML控件属性
  • C++访问QML控件及子控件属性
  • C++访问QML控件内函数
  • QML触发信号,C++侧接收信号
  • C++触发QML侧信号,QML接收信号

创建一个QML项目,其中main.qml文件如下

bash 复制代码
Window {
    visible: true
    width: 640
    height: 480
    title: qsTr("Hello World")

    Rectangle
    {
    		 objectName: "innerRect"
        width: 100
        height: 200
        anchors.centerIn: parent
        color: "red"
    }
}

C++访问QML控件属性

engine是QML加载引擎,通过该引擎可以拿到Window控件的对象(engine.rootObjects()返回一个列表)

QObject* rootObj = qmlObjList.first(); //拿到QML控件Window

需包含QQmlProperty头文件可以属性设置

QQmlProperty(rootObj, "title").write("Hello QML"); //对属性设置

QQmlProperty(rootObj, "width").write(700);

#C++访问QML子控件属性

通过rootObj->findChild<QObject*>("innerRect")得到子控件对象,"innerRect"是qml中objectName属性

C++访问QML控件内函数

如下qml中定义函数testFunc包含一个入参和返回值

C++通过QMetaObject::invokeMethod调用传入入参并接收返回值即可完成

C++触发QML侧信号,QML接收信号

bash 复制代码
Window {
    visible: true
    width: 640
    height: 480
    title: qsTr("Hello World")

    //qml端信号,C++触发信号
    signal qmlTestSig()

    //qmlTestSig对应槽函数
    onQmlTestSig:
    {
        console.log("qmlTestSig signal called");
    }

    Rectangle
    {
        objectName: "innerRect"
        width: 100
        height: 200
        anchors.centerIn: parent
        color: "red"
    }
}

如上qml侧定义信号,C++侧QMetaObject::invokeMethod触发

QML触发信号,C++侧接收信号

qml侧信号定义

如上MyTest负责接收信号

QML调用C++对象属性

首先创建C++对象,通过Q_PROPERTY设置属性

注册C++对象给QML使用

QML使用C++对象属性

相关推荐
Stella Blog2 小时前
狂神Java基础学习笔记Day04
java·笔记·学习
RReality2 小时前
【Unity Shader URP】Matcap 材质捕捉实战教程
java·ui·unity·游戏引擎·图形渲染·材质
代码中介商2 小时前
C语言函数完全指南:从基础到实践
c语言·开发语言
Yungoal2 小时前
项目层级结构
c++
思茂信息2 小时前
CST交叉cable的串扰(crosstalk)仿真
服务器·开发语言·人工智能·php·cst
lolo大魔王2 小时前
Go语言的反射机制
开发语言·后端·算法·golang
那个失眠的夜2 小时前
AspectJ
java·开发语言·数据库·spring
程序员-King.3 小时前
【基础分析】—— 条件变量wait(lock, 谓词)
c++·c·多线程·条件变量
杨凯凡3 小时前
【014】基本类型与包装类:缓存、相等性、NPE
java·数据结构·缓存