From c837319767bb609c6ec806336e49a347c77b11d3 Mon Sep 17 00:00:00 2001 From: Sine Striker <trueful@163.com> Date: 周五, 22 12月 2023 21:30:53 +0800 Subject: [PATCH] Add non-system-border option on Windows --- examples/mainwindow/mainwindow.cpp | 36 ++++++++++++++++++++---------------- 1 files changed, 20 insertions(+), 16 deletions(-) diff --git a/examples/mainwindow/mainwindow.cpp b/examples/mainwindow/mainwindow.cpp index 508df7b..7faf057 100644 --- a/examples/mainwindow/mainwindow.cpp +++ b/examples/mainwindow/mainwindow.cpp @@ -8,10 +8,14 @@ #include <QtWidgets/QApplication> #include <QtWidgets/QStyle> #include <QtWidgets/QPushButton> -#include <QtWidgets/QActionGroup> +#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0) +# include <QtGui/QActionGroup> +#else +# include <QtWidgets/QActionGroup> +#endif +#include <QWKCore/styleagent.h> #include <QWKWidgets/widgetwindowagent.h> -#include <QWKStyleSupport/styleagent.h> #include <widgetframe/windowbar.h> #include <widgetframe/windowbutton.h> @@ -33,8 +37,7 @@ MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) { installWindowAgent(); - - styleAgent = new QWK::StyleAgent(this); + installStyleAgent(); auto clockWidget = new ClockWidget(); clockWidget->setObjectName(QStringLiteral("clock-widget")); @@ -139,36 +142,32 @@ #ifdef Q_OS_WIN auto dwmBlurAction = new QAction(tr("Enable DWM blur"), menuBar); dwmBlurAction->setCheckable(true); - connect(dwmBlurAction, &QAction::triggered, this, [this](bool checked){ - QWindow *w = windowHandle(); - styleAgent->setWindowAttribute(w, QStringLiteral("dwm-blur"), checked); + connect(dwmBlurAction, &QAction::triggered, this, [this](bool checked) { + windowAgent->setWindowAttribute(QStringLiteral("dwm-blur"), checked); setProperty("custom-style", checked); style()->polish(this); }); auto acrylicAction = new QAction(tr("Enable acrylic material"), menuBar); acrylicAction->setCheckable(true); - connect(acrylicAction, &QAction::triggered, this, [this](bool checked){ - QWindow *w = windowHandle(); - styleAgent->setWindowAttribute(w, QStringLiteral("acrylic-material"), QColor()); + connect(acrylicAction, &QAction::triggered, this, [this](bool checked) { + windowAgent->setWindowAttribute(QStringLiteral("acrylic-material"), QColor::fromRgbF(1.f, 1.f, 1.f, 0.6f)); setProperty("custom-style", checked); style()->polish(this); }); auto micaAction = new QAction(tr("Enable mica"), menuBar); micaAction->setCheckable(true); - connect(micaAction, &QAction::triggered, this, [this](bool checked){ - QWindow *w = windowHandle(); - styleAgent->setWindowAttribute(w, QStringLiteral("mica"), checked); + connect(micaAction, &QAction::triggered, this, [this](bool checked) { + windowAgent->setWindowAttribute(QStringLiteral("mica"), checked); setProperty("custom-style", checked); style()->polish(this); }); auto micaAltAction = new QAction(tr("Enable mica alt"), menuBar); micaAltAction->setCheckable(true); - connect(micaAltAction, &QAction::triggered, this, [this](bool checked){ - QWindow *w = windowHandle(); - styleAgent->setWindowAttribute(w, QStringLiteral("mica-alt"), checked); + connect(micaAltAction, &QAction::triggered, this, [this](bool checked) { + windowAgent->setWindowAttribute(QStringLiteral("mica-alt"), checked); setProperty("custom-style", checked); style()->polish(this); }); @@ -283,10 +282,15 @@ #endif } +void MainWindow::installStyleAgent() { + styleAgent = new QWK::StyleAgent(this); +} + void MainWindow::loadStyleSheet(Theme theme) { if (!styleSheet().isEmpty() && theme == currentTheme) return; currentTheme = theme; + if (QFile qss(theme == Dark ? QStringLiteral(":/dark-style.qss") : QStringLiteral(":/light-style.qss")); qss.open(QIODevice::ReadOnly | QIODevice::Text)) { -- Gitblit v1.9.1