在QDialog中嵌入QML

  在一些一开始使用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();
            }
        }
    }
}

相关推荐

  1. <span style='color:red;'>QDialog</span>

    QDialog

    2024-03-11 19:38:04      48 阅读
  2. qml学习笔记】qml连接信号与槽

    2024-03-11 19:38:04       27 阅读
  3. 【QT教程】QT6 QML工业控制系统的应用

    2024-03-11 19:38:04       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-11 19:38:04       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-11 19:38:04       106 阅读
  3. 在Django里面运行非项目文件

    2024-03-11 19:38:04       87 阅读
  4. Python语言-面向对象

    2024-03-11 19:38:04       96 阅读

热门阅读

  1. 如何在程序中写一个日志程序,linux,c++

    2024-03-11 19:38:04       48 阅读
  2. AI辅助研发:引领科技创新的未来之路

    2024-03-11 19:38:04       50 阅读
  3. JVM内存结构

    2024-03-11 19:38:04       39 阅读
  4. Kafka - This server does not host this topic-partition

    2024-03-11 19:38:04       40 阅读
  5. TensorFlow简要介绍

    2024-03-11 19:38:04       39 阅读
  6. 掌握uboot使用的2个关键点:命令和环境变量

    2024-03-11 19:38:04       37 阅读
  7. CCIE路由交换考试指南

    2024-03-11 19:38:04       46 阅读
  8. [2024年]-flink面试真题(四)

    2024-03-11 19:38:04       47 阅读
  9. react recharts饼图 及配置项

    2024-03-11 19:38:04       36 阅读
  10. 【计算机网络教程】第一章课后习题答案

    2024-03-11 19:38:04       42 阅读
  11. linux系统nginx常用命令

    2024-03-11 19:38:04       44 阅读
  12. Claude与ChatGPT的对比

    2024-03-11 19:38:04       40 阅读
  13. uniapp地图围栏代码

    2024-03-11 19:38:04       43 阅读
  14. mysql笔记:5. 运算符

    2024-03-11 19:38:04       37 阅读