diff --git a/Telegram/SourceFiles/platform/win/integration_win.cpp b/Telegram/SourceFiles/platform/win/integration_win.cpp index 72c1783b34f7a1..b8d53a506ac585 100644 --- a/Telegram/SourceFiles/platform/win/integration_win.cpp +++ b/Telegram/SourceFiles/platform/win/integration_win.cpp @@ -12,6 +12,7 @@ For license and copyright information please follow this link: #include "core/application.h" #include "core/core_settings.h" #include "core/sandbox.h" +#include "tray.h" #include "base/platform/win/base_windows_winrt.h" #include @@ -78,11 +79,12 @@ bool WindowsIntegration::processEvent( } break; -#if QT_VERSION < QT_VERSION_CHECK(6, 5, 0) case WM_SETTINGCHANGE: +#if QT_VERSION < QT_VERSION_CHECK(6, 5, 0) Core::App().settings().setSystemDarkMode(Platform::IsDarkMode()); - break; #endif // Qt < 6.5.0 + Core::App().tray().updateIconCounters(); + break; } return false; } diff --git a/Telegram/SourceFiles/platform/win/main_window_win.cpp b/Telegram/SourceFiles/platform/win/main_window_win.cpp index 45ec3fc6c844ff..8c852b837ade1b 100644 --- a/Telegram/SourceFiles/platform/win/main_window_win.cpp +++ b/Telegram/SourceFiles/platform/win/main_window_win.cpp @@ -510,10 +510,12 @@ void MainWindow::updateTaskbarAndIconCounters() { auto iconSmallPixmap16 = Tray::IconWithCounter( Tray::CounterLayerArgs(16, counter, muted), true, + false, supportMode); auto iconSmallPixmap32 = Tray::IconWithCounter( Tray::CounterLayerArgs(32, counter, muted), true, + false, supportMode); QIcon iconSmall, iconBig; iconSmall.addPixmap(iconSmallPixmap16); @@ -524,10 +526,12 @@ void MainWindow::updateTaskbarAndIconCounters() { iconBig.addPixmap(Tray::IconWithCounter( Tray::CounterLayerArgs(32, bigCounter, muted), false, + false, supportMode)); iconBig.addPixmap(Tray::IconWithCounter( Tray::CounterLayerArgs(64, bigCounter, muted), false, + false, supportMode)); destroyCachedIcons(); diff --git a/Telegram/SourceFiles/platform/win/tray_win.cpp b/Telegram/SourceFiles/platform/win/tray_win.cpp index a0927702e3ba0b..1d99df169457f5 100644 --- a/Telegram/SourceFiles/platform/win/tray_win.cpp +++ b/Telegram/SourceFiles/platform/win/tray_win.cpp @@ -30,13 +30,47 @@ namespace { constexpr auto kTooltipDelay = crl::time(10000); +[[nodiscard]] std::optional IsDarkTaskbar() { + static const auto kSystemVersion = QOperatingSystemVersion::current(); + static const auto kDarkModeAddedVersion = QOperatingSystemVersion( + QOperatingSystemVersion::Windows, + 10, + 0, + 17763); + static const auto kSupported = (kSystemVersion >= kDarkModeAddedVersion); + if (!kSupported) { + return std::nullopt; + } + + const auto keyName = L"" + "Software\\Microsoft\\Windows\\CurrentVersion\\Themes\\Personalize"; + const auto valueName = L"SystemUsesLightTheme"; + auto key = HKEY(); + auto result = RegOpenKeyEx(HKEY_CURRENT_USER, keyName, 0, KEY_READ, &key); + if (result != ERROR_SUCCESS) { + return std::nullopt; + } + + DWORD value = 0, type = 0, size = sizeof(value); + result = RegQueryValueEx(key, valueName, 0, &type, (LPBYTE)&value, &size); + RegCloseKey(key); + if (result != ERROR_SUCCESS) { + return std::nullopt; + } + + return (value == 0); +} + [[nodiscard]] QImage ImageIconWithCounter( Window::CounterLayerArgs &&args, bool supportMode, - bool smallIcon) { + bool smallIcon, + bool monochrome) { static constexpr auto kCount = 3; static auto ScaledLogo = std::array(); static auto ScaledLogoNoMargin = std::array(); + static auto ScaledLogoDark = std::array(); + static auto ScaledLogoLight = std::array(); struct Dimensions { int index = 0; @@ -63,19 +97,49 @@ constexpr auto kTooltipDelay = crl::time(10000); }(); Assert(d.index < kCount); - auto &scaled = smallIcon ? ScaledLogoNoMargin : ScaledLogo; + const auto darkMode = IsDarkTaskbar(); + auto &scaled = (monochrome && darkMode) + ? (*darkMode + ? ScaledLogoDark + : ScaledLogoLight) + : smallIcon + ? ScaledLogoNoMargin + : ScaledLogo; + auto result = [&] { auto &image = scaled[d.index]; if (image.isNull()) { - image = (smallIcon - ? Window::LogoNoMargin() - : Window::Logo()).scaledToWidth( - d.size, - Qt::SmoothTransformation); + if (monochrome && darkMode) { + const auto withColor = [&](QColor color) { + switch (d.size) { + case 16: + return st::macTrayIcon.instance(color, 100 / cIntRetinaFactor()); + case 32: + return st::macTrayIcon.instance(color, 200 / cIntRetinaFactor()); + default: + return st::macTrayIcon.instance(color, 300 / cIntRetinaFactor()); + } + }; + const auto darkModeResult = withColor({ 255, 255, 255 }); + const auto lightModeResult = withColor({ 0, 0, 0, 228 }); + image = *darkMode ? darkModeResult : lightModeResult; + const auto monochromeMargin = QPoint( + (image.width() - d.size) / 2, + (image.height() - d.size) / 2); + image = image.copy( + QRect(monochromeMargin, QSize(d.size, d.size))); + image.setDevicePixelRatio(1); + } else { + image = (smallIcon + ? Window::LogoNoMargin() + : Window::Logo()).scaledToWidth( + d.size, + Qt::SmoothTransformation); + } } return image; }(); - if (supportMode) { + if ((!monochrome || !darkMode) && supportMode) { Window::ConvertIconToBlack(result); } if (!args.count) { @@ -163,10 +227,12 @@ void Tray::updateIcon() { auto iconSmallPixmap16 = Tray::IconWithCounter( CounterLayerArgs(16, counter, muted), true, + true, supportMode); auto iconSmallPixmap32 = Tray::IconWithCounter( CounterLayerArgs(32, counter, muted), true, + true, supportMode); auto iconSmall = QIcon(); iconSmall.addPixmap(iconSmallPixmap16); @@ -271,9 +337,10 @@ Window::CounterLayerArgs Tray::CounterLayerArgs( QPixmap Tray::IconWithCounter( Window::CounterLayerArgs &&args, bool smallIcon, + bool monochrome, bool supportMode) { return Ui::PixmapFromImage( - ImageIconWithCounter(std::move(args), supportMode, smallIcon)); + ImageIconWithCounter(std::move(args), supportMode, smallIcon, monochrome)); } } // namespace Platform diff --git a/Telegram/SourceFiles/platform/win/tray_win.h b/Telegram/SourceFiles/platform/win/tray_win.h index e399e5945381aa..53631e55657a35 100644 --- a/Telegram/SourceFiles/platform/win/tray_win.h +++ b/Telegram/SourceFiles/platform/win/tray_win.h @@ -57,6 +57,7 @@ class Tray final { [[nodiscard]] static QPixmap IconWithCounter( Window::CounterLayerArgs &&args, bool smallIcon, + bool monochrome, bool supportMode); private: