From 8517f5b133f1aceff893a1a01417157136fe0715 Mon Sep 17 00:00:00 2001 From: Sine Striker <trueful@163.com> Date: 周一, 01 1月 2024 13:33:29 +0800 Subject: [PATCH] Add license and prepare to release --- src/core/style/styleagent_win.cpp | 73 +++++++++++++++++------------------- 1 files changed, 35 insertions(+), 38 deletions(-) diff --git a/src/core/style/styleagent_win.cpp b/src/core/style/styleagent_win.cpp index 6b77012..f6b92e8 100644 --- a/src/core/style/styleagent_win.cpp +++ b/src/core/style/styleagent_win.cpp @@ -1,3 +1,6 @@ +// Copyright (C) 2023-2024 Stdware Collections +// SPDX-License-Identifier: Apache-2.0 + #include "styleagent_p.h" #include <QtCore/QSet> @@ -12,6 +15,23 @@ using StyleAgentSet = QSet<StyleAgentPrivate *>; Q_GLOBAL_STATIC(StyleAgentSet, g_styleAgentSet) + static StyleAgent::SystemTheme getSystemTheme() { + if (isHighContrastModeEnabled()) { + return StyleAgent::HighContrast; + } else if (isDarkThemeActive()) { + return StyleAgent::Dark; + } else { + return StyleAgent::Light; + } + } + + static void notifyAllStyleAgents() { + auto theme = getSystemTheme(); + for (auto &&ap : std::as_const(*g_styleAgentSet())) { + ap->notifyThemeChanged(theme); + } + } + class SystemSettingEventFilter : public AppNativeEventFilter { public: bool nativeEventFilter(const QByteArray &eventType, void *message, @@ -21,42 +41,25 @@ return false; } - auto themeChanged = [message]() -> bool { - const auto msg = static_cast<const MSG *>(message); - switch (msg->message) { - case WM_THEMECHANGED: - case WM_SYSCOLORCHANGE: - case WM_DWMCOLORIZATIONCOLORCHANGED: - return true; - - case WM_SETTINGCHANGE: { - if (isImmersiveColorSetChange(msg->wParam, msg->lParam)) { - return true; - } - break; - } - - default: - break; + const auto msg = static_cast<const MSG *>(message); + switch (msg->message) { + case WM_THEMECHANGED: + case WM_SYSCOLORCHANGE: + case WM_DWMCOLORIZATIONCOLORCHANGED: { + notifyAllStyleAgents(); + break; } - return false; - }(); - if (themeChanged) { - auto theme = []() -> StyleAgent::SystemTheme { - if (isHighContrastModeEnabled()) { - return StyleAgent::HighContrast; - } else if (isDarkThemeActive()) { - return StyleAgent::Dark; - } else { - return StyleAgent::Light; + case WM_SETTINGCHANGE: { + if (isImmersiveColorSetChange(msg->wParam, msg->lParam)) { + notifyAllStyleAgents(); } - }(); - for (auto &&ap : std::as_const(*g_styleAgentSet())) { - ap->notifyThemeChanged(theme); + break; } + + default: + break; } - return false; } @@ -81,13 +84,7 @@ SystemSettingEventFilter *SystemSettingEventFilter::instance = nullptr; void StyleAgentPrivate::setupSystemThemeHook() { - if (isHighContrastModeEnabled()) { - systemTheme = StyleAgent::HighContrast; - } else if (isDarkThemeActive()) { - systemTheme = StyleAgent::Dark; - } else { - systemTheme = StyleAgent::Light; - } + systemTheme = getSystemTheme(); g_styleAgentSet->insert(this); SystemSettingEventFilter::install(); -- Gitblit v1.9.1