在QDialog中嵌入QML

本文介绍了如何在老旧项目中将QWidget与QML结合,以QDialog形式创建一个全屏透明弹框,并加载QML文件以显示提示信息。详细步骤包括设置窗口属性、添加QQuickWidget以及配置QML文件中的组件。
摘要由CSDN通过智能技术生成

  在一些一开始使用QWidget的项目,现由于要支持的硬件及系统已升级,可以很好的使用QML。在这种情况下,就需要通过QWidget与QML混合使用的方式来慢慢把整个项目过渡到纯QML工程。这时在QWidget中嵌入QML是经常要做的事,现就说一说在QDialog中嵌入QML的实现方式。
  项目中需要使用覆盖整个应用窗口的弹框且背景透明显来突出显示提示信息。
实现的效果
首先需要自定义基于QDialog的子类,通过setWindowFlags方法,把dialog设置为无边框,然后再通过setAttribute设置dialog的背景透明。

setWindowFlags(Qt::Dialog | Qt::FramelessWindowHint);
setAttribute(Qt::WA_TranslucentBackground);

获取应用主窗口的size,如果没有把主窗口共享出来,就需要通过QApplication的qApp宏来获取activeWindow。得到Window之后,通过geometry获取到窗口的Rect信息,然后设置dialog的size,并把dialog放在坐标系(0,0)的位置。

QRect rect = window->geometry();
qDebug() << rect;
this->resize(rect.size());
this->move(rect.topLeft());

之后,在该dialog中添加QQuickWidget用来加载qml文件。

    QVBoxLayout *vLayout = new QVBoxLayout;
    QQuickWidget *quickWidget = new QQuickWidget;
    vLayout->addWidget(quickWidget);
    setLayout(vLayout);
    quickWidget->setResizeMode(QQuickWidget::SizeRootObjectToView);
    quickWidget->engine()->rootContext()->setContextProperty("applicationDirPath", QGuiApplication::applicationDirPath());
    quickWidget->setSource(QUrl("qrc:/CommonMessageBox.qml"));
    quickWidget->rootObject()->setProperty("msg", "full-2024-03-03 19-32-01-246.jpg");
    quickWidget->setClearColor(QColor(Qt::transparent));

qml文件代码

import QtQuick 2.15
import QtQuick.Controls


Rectangle {
    id:idRectBg
    // width: 800
    // height: 600
    property string msg: ""

    color: "transparent"

    signal sigCloseSignal();

    

    Rectangle {
        id:idItemBlur
        anchors.fill: parent
        color: "#DEced4da"
        smooth: true

    }

    

    Rectangle {
        id:idRectTitle

        width: parent.width - 100
        height: 200
        anchors.centerIn: parent
        color: "#669bbc"

        Text {
            id:idTextTitle
            anchors.centerIn: parent
            text: msg
        }

        Button {
            id:idBtnClose
            anchors.right: parent.right
            anchors.top: parent.top
            width: 50
            height: 50
            text: "X"
            onClicked: {
                idRectTitle.visible = false;
                sigCloseSignal();
            }
        }
    }
}
  • 8
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值