25. 在QWidget窗口中嵌入QML界面
创始人
2025-05-30 10:00:04
0

1. 说明:

QML开发界面是最近才开始流行,在之前的老项目中一般都是使用QWidget进行开发,其界面设计不是很美观,但能够实现的功能是挺多的,这些是QML无法实现的。如果想在QWidget的基础上对界面进行美化,则可以将QML界面嵌入到QWidget当中进行使用。与QML界面嵌入QWidget窗口这篇博客也有共通之处。
效果展示

QWidget窗口加载QML界面

2. 实现方式:

将QML界面嵌入到QWidget窗口当中,主要利用到的控件是QQuickWidget小控件。因为要使用到QWidget,所以要在项目的.pro文件中加入quickwidgets库:QT += quickwidgets

2.1 第一步:

首先,创建一个QWidget框架的项目,并在界面当中拖入一个QQuickWidget控件,如下图所示:
在这里插入图片描述

2.2 第二步:

然后,创建一个QML文件用于加载到QWidget窗口中,因为用于承载qml页面的小控件是QQuickWidget,qml文件中根节点最好使用Item或者Rectangle,不要使用Window,可能会出错。本文章具体qml文件代码如下:

import QtQuick 2.15
import QtQuick.Controls 2.15Item {width: parent.widthheight: parent.heightvisible: truefunction toRed(){bck.color = "red"}function toBlue(){bck.color = "blue"}Rectangle{id:bckobjectName: "background"anchors.fill: parentcolor: Qt.rgba(0.0,0.0,0.0,0.5)}signal rectRed()signal rectBlue()Button{id:firstwidth: 100height: 50anchors.left: parent.leftanchors.leftMargin: 10anchors.verticalCenter: parent.verticalCentertext: "Red"onClicked: {rectRed()}}Button{id:secondwidth: 100height: 50anchors.right: parent.rightanchors.rightMargin: 10anchors.verticalCenter: parent.verticalCentertext: "Blue"onClicked: {rectBlue()}}
}

2.3 第三步:

加载QML文件之前,需要将QML文件以资源文件的形式放入到整个项目中进行使用。
在项目文件上右键鼠标,选择Add New…:
在这里插入图片描述
在弹出的窗口中选择***Qt -> Qt Resource File ***:
在这里插入图片描述
根据指引一步步将qml文件添加到资源文件中即可。

2.4 第四步:

在项目目录树中打开QWidget窗口对应的代码文件,在其中引入QML文件,在qml文件中定义了两个信号和两个函数,在widget窗口中对这两个信号进行连接,并在对应的槽函数中去调用qml中的函数,以改变qml界面的填充颜色。具体代码和注释如下:
Widget.h:

#ifndef WIDGET_H
#define WIDGET_H#include QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACEclass Widget : public QWidget
{Q_OBJECTpublic:Widget(QWidget *parent = nullptr);~Widget();public slots:void onRectRed();//槽函数,用于响应QML中的信号void onRectBlue();//槽函数,用于响应QML中的信号private:Ui::Widget *ui;
};
#endif // WIDGET_H

Widget.cpp:

#include "widget.h"
#include "ui_widget.h"
#include Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);QUrl source("qrc:/qmls/qmlInWidget.qml");//加载QML文件ui->quickWidget->setResizeMode(QQuickWidget::SizeRootObjectToView );//设置QML界面整体填充QQuickWidget控件ui->quickWidget->setSource(source);//指定加载源QQuickItem* item = ui->quickWidget->rootObject();//获取quickwidget中的qml根对象connect(item,SIGNAL(rectRed()),this,SLOT(onRectRed()));//连接QML中的信号connect(item,SIGNAL(rectBlue()),this,SLOT(onRectBlue()));//连接QML中的信号}Widget::~Widget()
{delete ui;
}void Widget::onRectRed()
{QQuickItem* item = ui->quickWidget->rootObject();QMetaObject::invokeMethod(item,"toRed");//调用QML中的方法
}void Widget::onRectBlue()
{QQuickItem* item = ui->quickWidget->rootObject();QMetaObject::invokeMethod(item,"toBlue");//调用QML中的方法
}

持续更新中,请大家多多关注…

相关内容

热门资讯

重庆啤酒或与嘉威啤酒和解 一亿... 中经记者 党鹏 成都报道12月15日晚间,重庆啤酒(600132.SH)发布公告称,重庆啤酒和重庆嘉...
美国布朗大学枪击案嫌疑人行踪监... ▲新京报我们视频出品(ID:wevideo) 12月16日,美国联邦调查局公布布朗大学枪击案嫌疑人案...
科研驱动行业发展!口服美容市场... 本文来源:时代周报 作者:赵鹏近年来,随着“颜值经济”的崛起,消费者对外貌的要求不断提高,与美容相关...
市场监管总局:企业跨省迁移实现... 12月16日,市场监管总局在2025年第四季度例行新闻发布会上宣布,自10月1日起,企业跨省迁移登记...
中美卫星相距200米惊险擦肩!... SpaceX“星链”高管近日在社交媒体发文“告状”,说我国近期发射的卫星事先没有协调避撞。 中科宇航...
【今晚播出】一场“无人”的马拉... 两说 Business Insights继2024年在纳斯达克上市后,小马智行近日在港交所上市,成为...
纳斯达克交易所申请“全天候”交... 全球最大交易所之一的纳斯达克交易所于当地时间周一(15日)向美国证券交易委员会(SEC)提交文件,申...
王子新材第三大股东王孝军辞世!... 12月16日,王子新材(002735.SZ)公告称,公司控股股东、实际控制人的一致行动人之一王孝军辞...
如何开展长寿风险管理?业内人士... 长寿是社会进步和发展的重要指标之一。同时,如何科学管理和分散长寿时代风险成为社会发展面临的新挑战。近...
2025:科技投资正酣,如何答... 每一个时代都有代表性的产业机会,把握当下的产业脉络,大概率就是好的投资方式。梳理过去近二十年的市场脉...