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++对象属性

相关推荐
唐青枫13 小时前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
一个做软件开发的牛马14 小时前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户37215742613514 小时前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java
用户37215742613514 小时前
Java 打印 Word 文档:从基础打印到高级设置
java
用户3521802454751 天前
当 Prompt 学会"热更新":Spring Boot × Nacos3 AI 实战
java·spring boot·ai编程
东坡白菜1 天前
破局全栈:一个前端开发的Java入门实战记录(1)
java·全栈
clint4561 天前
C++进阶(1)——前景提要
c++
唐青枫1 天前
Java Tomcat 实战指南:从 Servlet 容器到 Spring Boot 部署
java
wsaaaqqq1 天前
roudan:自由选择实体、灵活操作数据、快速写入数据库的 Java 框架
java
夜悊2 天前
C++代码示例:进制数简单生成工具
c++