From 5bfd136473edc506b860177bf88626e35a5a1ba4 Mon Sep 17 00:00:00 2001 From: SineStriker <trueful@163.com> Date: ćšć, 28 12æ 2023 12:06:54 +0800 Subject: [PATCH] Add mac blur view --- examples/mainwindow/mainwindow.cpp | 88 +++++++++++++++++++++++++++++++++---------- 1 files changed, 67 insertions(+), 21 deletions(-) diff --git a/examples/mainwindow/mainwindow.cpp b/examples/mainwindow/mainwindow.cpp index 173be17..154aa62 100644 --- a/examples/mainwindow/mainwindow.cpp +++ b/examples/mainwindow/mainwindow.cpp @@ -5,13 +5,16 @@ #include <QtCore/QTime> #include <QtCore/QTimer> #include <QtGui/QPainter> -#include <QtGui/QActionGroup> #include <QtWidgets/QApplication> #include <QtWidgets/QStyle> #include <QtWidgets/QPushButton> +#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0) +# include <QtGui/QActionGroup> +#else +# include <QtWidgets/QActionGroup> +#endif #include <QWKWidgets/widgetwindowagent.h> -#include <QWKStyleSupport/styleagent.h> #include <widgetframe/windowbar.h> #include <widgetframe/windowbutton.h> @@ -33,8 +36,6 @@ MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) { installWindowAgent(); - - styleAgent = new QWK::StyleAgent(this); auto clockWidget = new ClockWidget(); clockWidget->setObjectName(QStringLiteral("clock-widget")); @@ -139,56 +140,100 @@ #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::toggled, this, [this](bool checked) { + if (!windowAgent->setWindowAttribute(QStringLiteral("dwm-blur"), checked)) { + return; + } 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::toggled, this, [this](bool checked) { + if (!windowAgent->setWindowAttribute(QStringLiteral("acrylic-material"), true)) { + return; + } 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::toggled, this, [this](bool checked) { + if (!windowAgent->setWindowAttribute(QStringLiteral("mica"), checked)) { + return; + } 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::toggled, this, [this](bool checked) { + if (!windowAgent->setWindowAttribute(QStringLiteral("mica-alt"), checked)) { + return; + } setProperty("custom-style", checked); style()->polish(this); }); +#elif defined(Q_OS_MAC) + auto darkBlurAction = new QAction(tr("Dark blur"), menuBar); + darkBlurAction->setCheckable(true); + connect(darkBlurAction, &QAction::toggled, this, [this](bool checked) { + if (!windowAgent->setWindowAttribute(QStringLiteral("blur-effect"), "dark")) { + return; + } + if (checked) { + setProperty("custom-style", true); + style()->polish(this); + } + }); - auto winStyleGroup = new QActionGroup(menuBar); - winStyleGroup->addAction(dwmBlurAction); - winStyleGroup->addAction(acrylicAction); - winStyleGroup->addAction(micaAction); - winStyleGroup->addAction(micaAltAction); + auto lightBlurAction = new QAction(tr("Light blur"), menuBar); + lightBlurAction->setCheckable(true); + connect(lightBlurAction, &QAction::toggled, this, [this](bool checked) { + if (!windowAgent->setWindowAttribute(QStringLiteral("blur-effect"), "light")) { + return; + } + if (checked) { + setProperty("custom-style", true); + style()->polish(this); + } + }); + + auto noBlurAction = new QAction(tr("No blur"), menuBar); + noBlurAction->setCheckable(true); + connect(noBlurAction, &QAction::toggled, this, [this](bool checked) { + if (!windowAgent->setWindowAttribute(QStringLiteral("blur-effect"), "none")) { + return; + } + if (checked) { + setProperty("custom-style", false); + style()->polish(this); + } + }); + + auto macStyleGroup = new QActionGroup(menuBar); + macStyleGroup->addAction(darkBlurAction); + macStyleGroup->addAction(lightBlurAction); + macStyleGroup->addAction(noBlurAction); #endif // Real menu auto settings = new QMenu(tr("Settings(&S)"), menuBar); settings->addAction(darkAction); + #ifdef Q_OS_WIN settings->addSeparator(); settings->addAction(dwmBlurAction); settings->addAction(acrylicAction); settings->addAction(micaAction); settings->addAction(micaAltAction); +#elif defined(Q_OS_MAC) + settings->addAction(darkBlurAction); + settings->addAction(lightBlurAction); + settings->addAction(noBlurAction); #endif menuBar->addMenu(file); @@ -287,6 +332,7 @@ 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