【QML】QML与C++混合编程

简介: 【QML】QML与C++混合编程

QML与C++混合编程

使用QQuickView

pro文件中添加quick模块

#include<QApplication>
#include<QQuickView>

int main(int argc,char* argv[]){
    QApplication app(argc,argv);
    
    //加载qml文件到视图
    QQuickView view;
    view.setSource(QUrl("column.qml"));
    view.show();

    return app.exec();
}

使用QQmlApplicationEngine

创建Qt Quick Application

#include <QGuiApplication>
#include <QQmlApplicationEngine>

int main(int argc, char *argv[])
{
    //支持高频率屏幕
    QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);

    QGuiApplication app(argc, argv);

    //创建qml引擎
    QQmlApplicationEngine engine;

    //引擎加载qml文件
    engine.load(QUrl(QStringLiteral("qrc:/main.qml")));
    if (engine.rootObjects().isEmpty())
        return -1;

    return app.exec();
}

QML调用C++函数

#ifndef APPLICATIONDATA_H
#define APPLICATIONDATA_H

#include <QObject>
#include <QDateTime>

class ApplicationData : public QObject
{
    Q_OBJECT
public:
    explicit ApplicationData(QObject *parent = nullptr);
    //QML中调用C++函数,这个函数需以Q_INVOKABLE进行标记——注册一个方法到QML
    //或者该函数是Qt的槽函数
    Q_INVOKABLE QDateTime getCurrentDateTime()const{
        return QDateTime::currentDateTime();
    }

signals:

public slots:
};

#endif // APPLICATIONDATA_H
#include <QApplication>
#include <QQuickView>
#include "applicationdata.h"
#include <QQmlContext>

int main(int argc,char* argv[]){
    QApplication app(argc,argv);
    QQuickView view;

    //将C++对象作为属性注册到QML
    ApplicationData data;
    view.rootContext()->setContextProperty("applicationData",&data);
    view.setSource(QUrl("item.qml"));
    view.show();
    return app.exec();
}
import QtQuick 2.0

Text{
    text: applicationData.getCurrentDateTime()

}

C++调用QML函数

import QtQuick 2.0

Text{
    text: applicationData.getCurrentDateTime()
    function qmlFunction(msg){
        console.log("Message comes:",msg)
        return "abc"
    }
}
#include <QApplication>
#include <QQuickView>
#include "applicationdata.h"
#include <QQmlContext>
#include <QQmlApplicationEngine>
#include <QQmlComponent>

int main(int argc,char* argv[]){
    QApplication app(argc,argv);

    QQmlApplicationEngine engine;
    QQmlComponent component(&engine,"item.qml");
    QObject* object = component.create();
    QVariant msg = "Hello qml!";
    QVariant returnedValue;

    //invokeMethod的 Q_RETURN_ARG       Q_ARG参数必须指定为QVariant类型
    QMetaObject::invokeMethod(
         object,
         "qmlFunction",                                               Q_RETURN_ARG(QVariant,returnedValue),//用于接收返回值
         Q_ARG(QVariant,msg));//用于传递函数函数
    qDebug()<<"QML function returned:"<<returnedValue.toString();


    return app.exec();
}

C++接收QML信号

import QtQuick 2.0

Item {
    id:item
    width:100
    height: 100

    signal qmlSignal(string msg)

    MouseArea{
        anchors.fill: parent
        onClicked: item.qmlSignal("Hello qml")
    }
}
#include <QApplication>
#include <QQuickView>
#include<QQuickItem>
#include "myclass.h"


int main(int argc,char* argv[]){
    QApplication app(argc,argv);

    QQuickView view(QUrl::fromLocalFile("quicksignal.qml"));

    QObject* item = view.rootObject();

    MyClass myClass;
    QObject::connect(item,
                     SIGNAL(qmlSignal(QString)),
                     &myClass,
                     SLOT(slotPrint(QString)));
    view.show();
    return app.exec();
}
#ifndef MYCLASS_H
#define MYCLASS_H

#include <QObject>
#include <QDebug>

class MyClass : public QObject
{
    Q_OBJECT
public:
    explicit MyClass(QObject *parent = nullptr);


signals:

public slots:
    void slotPrint(QString s){
        qDebug()<<s;
    }
};

#endif // MYCLASS_H
相关文章
|
前端开发 算法 数据可视化
第三代软件开发-C++&QML交互
欢迎来到我们的 QML & C++ 项目!这个项目结合了 QML(Qt Meta-Object Language)和 C++ 的强大功能,旨在开发出色的用户界面和高性能的后端逻辑。 在项目中,我们利用 QML 的声明式语法和可视化设计能力创建出现代化的用户界面。通过直观的编码和可重用的组件,我们能够迅速开发出丰富多样的界面效果和动画效果。同时,我们利用 QML 强大的集成能力,轻松将 C++ 的底层逻辑和数据模型集成到前端界面中。 在后端方面,我们使用 C++ 编写高性能的算法、数据处理和计算逻辑。C++ 是一种强大的编程语言,能够提供卓越的性能和可扩展性。我们的团队致力于优化代码,减少资
|
2月前
|
C++ Python
探索Python与C/C++混合编程的艺术
探索Python与C/C++混合编程的艺术
55 1
|
3月前
|
Java Android开发 C++
🚀Android NDK开发实战!Java与C++混合编程,打造极致性能体验!📊
在Android应用开发中,追求卓越性能是不变的主题。本文介绍如何利用Android NDK(Native Development Kit)结合Java与C++进行混合编程,提升应用性能。从环境搭建到JNI接口设计,再到实战示例,全面展示NDK的优势与应用技巧,助你打造高性能应用。通过具体案例,如计算斐波那契数列,详细讲解Java与C++的协作流程,帮助开发者掌握NDK开发精髓,实现高效计算与硬件交互。
169 1
|
3月前
|
前端开发 C++ Windows
C++生成QML代码与QML里面集成QWidget
这篇文章介绍了如何在C++中生成QML代码,以及如何在QML中集成QWidget,包括使用Qt Widgets嵌入到QML界面中的技术示例。
|
5月前
|
Java Android开发 C++
🚀Android NDK开发实战!Java与C++混合编程,打造极致性能体验!📊
【7月更文挑战第28天】在 Android 开发中, NDK 让 Java 与 C++ 混合编程成为可能, 从而提升应用性能。**为何选 NDK?** C++ 在执行效率与内存管理上优于 Java, 特别适合高性能需求场景。**环境搭建** 需 Android Studio 和 NDK, 工具如 CMake。**JNI** 构建 Java-C++ 交互, 通过声明 `native` 方法并在 C++ 中实现。**实战** 示例: 使用 C++ 计算斐波那契数列以提高效率。**总结** 混合编程增强性能, 但增加复杂性, 使用前需谨慎评估。
154 4
|
6月前
|
编译器 C语言 C++
|
7月前
|
Java API C++
【C++ 与Qt 线程】C++ std::thread 与Qt qthread多线程混合编程
【C++ 与Qt 线程】C++ std::thread 与Qt qthread多线程混合编程
286 1
|
7月前
|
JavaScript 前端开发 安全
【QML 与 C++ 之间的通讯机制】QML 与 Qt 通讯:讲解如何在QML 中使用C++类,以及如何在C++ 中获取QML的内容
【QML 与 C++ 之间的通讯机制】QML 与 Qt 通讯:讲解如何在QML 中使用C++类,以及如何在C++ 中获取QML的内容
825 1
|
并行计算 Linux C++
Linux上C++与CUDA混合编程
Linux上C++与CUDA混合编程
|
开发框架 .NET C#
C#调用C++托管类,实现C#和C++的混合编程
C#调用C++托管类,实现C#和C++的混合编程
546 0
C#调用C++托管类,实现C#和C++的混合编程