Skip to content

Commit

Permalink
Implement monochrome tray icon on Windows
Browse files Browse the repository at this point in the history
  • Loading branch information
ilya-fedin authored and john-preston committed Oct 25, 2023
1 parent 1f25301 commit cd0f58f
Show file tree
Hide file tree
Showing 4 changed files with 85 additions and 11 deletions.
6 changes: 4 additions & 2 deletions Telegram/SourceFiles/platform/win/integration_win.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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 <QtCore/QCoreApplication>
Expand Down Expand Up @@ -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;
}
Expand Down
4 changes: 4 additions & 0 deletions Telegram/SourceFiles/platform/win/main_window_win.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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);
Expand All @@ -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();
Expand Down
85 changes: 76 additions & 9 deletions Telegram/SourceFiles/platform/win/tray_win.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,47 @@ namespace {

constexpr auto kTooltipDelay = crl::time(10000);

[[nodiscard]] std::optional<bool> 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<QImage, kCount>();
static auto ScaledLogoNoMargin = std::array<QImage, kCount>();
static auto ScaledLogoDark = std::array<QImage, kCount>();
static auto ScaledLogoLight = std::array<QImage, kCount>();

struct Dimensions {
int index = 0;
Expand All @@ -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) {
Expand Down Expand Up @@ -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);
Expand Down Expand Up @@ -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
1 change: 1 addition & 0 deletions Telegram/SourceFiles/platform/win/tray_win.h
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ class Tray final {
[[nodiscard]] static QPixmap IconWithCounter(
Window::CounterLayerArgs &&args,
bool smallIcon,
bool monochrome,
bool supportMode);

private:
Expand Down

0 comments on commit cd0f58f

Please sign in to comment.