QML学习笔记(五十三)QML与C++交互:数据转换——序列类型与 JavaScript 数组的转换

前言

本节介绍一下序列类型和数组之间的转换,简单来说就是C++的QVetor和qml中的数组之间的转换。

一、代码示例

只展示核心代码:

cpp 复制代码
class CppClass : public QObject
{
    Q_OBJECT

public:
    explicit CppClass(QObject *parent = nullptr);

    Q_INVOKABLE void qmlArrayToCpp(QVector<QString> vector);
    Q_INVOKABLE QVector<QString> retrieveStrings();
private:
    QVector<QString> mVector;
};
cpp 复制代码
#include "cppclass.h"
#include <QDebug>

CppClass::CppClass(QObject *parent) : QObject(parent)
{
    mVector.append("One");
    mVector.append("Two");
    mVector.append("Three");
    mVector.append("Four");
}

void CppClass::qmlArrayToCpp(QVector<QString> vector)
{
    foreach (QString string, vector){
        qDebug()<< string;
    }
}

QVector<QString> CppClass::retrieveStrings()
{
    return mVector;
}
cpp 复制代码
import QtQuick 2.14
import QtQuick.Window 2.14
import QtQuick.Controls 2.12
import com.mycompany 1.0

Window {
	// ...
    CppClass{
        id: cppClassId
    }

    Button{
        id: buttonId
    }
    Button{
        id:button1Id
        text:"Send to C++"
        x: buttonId.x + buttonId.width
        onClicked:function(){
            var arr = ['Apple', 'Banana','Avocado','Pear','Orange'];
            cppClassId.qmlArrayToCpp(arr)
        }
    }
    Button{
        id: button2Id
        text:"Read form C++"
        anchors.left: button1Id.right
        onClicked:function(){
            var arr = cppClassId.retrieveStrings()
            print("The length of the array is:"+ arr.length)
            arr.forEach(function(element){
                console.log(element)
            })
        }
    }
}

打印:

可以看到,其实并不需要什么特殊处理的转换,qt会自动匹配转换的。

二、总结

这种数组和序列的数据是很常见的变量,从C++发送到qml进行前端展示,或者从qml端搜集后要发送到C++端进行存储和管理都是很常见的需求。

相关推荐
HyperAI超神经31 分钟前
【vLLM 学习】Prefix Caching
人工智能·深度学习·学习·大语言模型·cpu·gpu·vllm
.小墨迹1 小时前
C++学习之std::move 的用法与优缺点分析
linux·开发语言·c++·学习·算法·ubuntu
看见繁华1 小时前
C++ 设计模式&设计原则
java·c++·设计模式
点云SLAM1 小时前
C++ error C2065: “M_PI”: 未声明的标识符 解决方案
开发语言·c++·error c2065·m_pi未声明 解决方案
草莓熊Lotso1 小时前
C++11 核心精髓:类新功能、lambda与包装器实战
开发语言·c++·人工智能·经验分享·后端·nginx·asp.net
黑客思维者1 小时前
机器学习007:监督学习【回归算法】(线性回归)--股票背后的预测学
学习·机器学习·回归·线性回归·监督学习
EniacCheng1 小时前
【RUST】学习笔记-整型
笔记·学习·rust
欧特克_Glodon1 小时前
C++医学图像处理经典ITK库用法详解<三>: 图像配准模块功能
c++·图像处理·vtk·图像配准
断剑zou天涯1 小时前
【算法笔记】树状数组IndexTree
java·笔记·算法
秦苒&1 小时前
【C语言指针四】数组指针变量、二维数组传参本质、函数指针变量、函数指针数组
c语言·开发语言·c++·c#