【Qt】Qt C++ Widget中嵌入qml

55 篇文章 1 订阅

1. 效果

在这里插入图片描述

2. 方法

  • 使用QQuickWidget方式
	QQuickWidget *view = new QQuickWidget;
    view->setSource(QUrl::fromLocalFile("myqmlfile.qml"));
    view->show();
  • 除了QQuickWidget方式还可以使用QQuickView方式,请自行查阅资料

3. 代码

3.1 工程目录

在这里插入图片描述

3.2 pro文件

备注:需要添加 quickwidgets

QT       += core gui quickwidgets

greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

CONFIG += c++17

# You can make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0

SOURCES += \
    main.cpp \
    dialog.cpp

HEADERS += \
    dialog.h

FORMS += \
    dialog.ui

# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target

DISTFILES +=

RESOURCES += \
    res.qrc

3.3 main.cpp

#include "dialog.h"

#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Dialog w;
    w.show();
    return a.exec();
}

3.4 dialog.h

#ifndef DIALOG_H
#define DIALOG_H

#include <QDialog>

QT_BEGIN_NAMESPACE
namespace Ui { class Dialog; }
QT_END_NAMESPACE

class Dialog : public QDialog
{
    Q_OBJECT

public:
    Dialog(QWidget *parent = nullptr);
    ~Dialog();

signals:
    cppClick();

public slots:
    void onQmlClick();

private slots:
    void on_pushButton_clicked();

private:
    Ui::Dialog *ui;
};
#endif // DIALOG_H

3.5 dialog.cpp

#include "dialog.h"
#include "ui_dialog.h"
#include <QtQuickWidgets>


Dialog::Dialog(QWidget *parent)
    : QDialog(parent)
    , ui(new Ui::Dialog)
{
    ui->setupUi(this);

    //c++向qml中传数据
    ui->quickWidget->rootContext()->setContextProperty("$color", "red");

    //qml导入
    QUrl source("qrc:/qmlFile.qml");
    ui->quickWidget->setResizeMode(QQuickWidget::SizeRootObjectToView);
    ui->quickWidget->setSource(source);
    ui->quickWidget->setClearColor(QColor(Qt::transparent));

    //qml与c++交互
    QQuickItem* qmlItem = ui->quickWidget->rootObject();
    connect(qmlItem, SIGNAL(qmlClick()), this, SLOT(onQmlClick()));
    connect(this, SIGNAL(cppClick()), qmlItem, SLOT(onCppClick()));
}

Dialog::~Dialog()
{
    delete ui;
}

void Dialog::onQmlClick()
{
    qDebug() << "this is C++: qml's click";
}


void Dialog::on_pushButton_clicked()
{
    emit cppClick();
}


3.6 qmlFile.qml

import QtQuick 2.15
import QtQuick.Controls 2.15

Item {
    id: _mRoot

    signal qmlClick();

    function onCppClick()
    {
        console.log("this is qml: cpp's click")
    }

    Rectangle{
        width: 200
        height: 200
        color: $color
        border.color: "grey"
        border.width: 1

        Button{
            width: 100
            height: 50
            text: "qml button"
            anchors.centerIn: parent

            onClicked: {
                qmlClick();
            }
        }
    }
}

3.7 dialog.ui

在这里插入图片描述

4. 参考

  • 7
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值