From 42c7e6848f61438f747c9509f17bef2dca29d937 Mon Sep 17 00:00:00 2001 From: Michael Weghorn Date: Mon, 21 Oct 2024 14:43:13 +0200 Subject: tdf#152534 Win 11 Dark: Draw toolbar button bg + frame manually When using the dark theme on Windows 11, the background color for toolbar buttons is light blue as with the light theme, which results in insufficient contrast. According to the comments in tdf#152534, this is is a in the Windows dark theme which can also be seen in other apps or has been worked around there, like in Notepad++ [1]. Work around the issue by not letting the theme draw the background (using Win API function `DrawThemeBackground`) when on Windows 11 and using dark theme, but manually draw the background and a frame instead for now. For the background color, use a color that's a bit lighter than the background color for non-highlighted items. [1] https://github.com/notepad-plus-plus/notepad-plus-plus/commit/5d086f93a80d275fcc5e4047ae49c614680a7e5b Change-Id: Ie35937fde2e8c7078c4979a2ef60c28fc4679574 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/175334 Reviewed-by: Michael Weghorn Tested-by: Jenkins (cherry picked from commit 620b293808f6111556c31674437917e70b106e9e) Reviewed-on: https://gerrit.libreoffice.org/c/core/+/175396 Reviewed-by: Adolfo Jayme Barrientos --- vcl/win/gdi/salnativewidgets-luna.cxx | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) (limited to 'vcl') diff --git a/vcl/win/gdi/salnativewidgets-luna.cxx b/vcl/win/gdi/salnativewidgets-luna.cxx index 318009acadae..4daad8eadc9b 100644 --- a/vcl/win/gdi/salnativewidgets-luna.cxx +++ b/vcl/win/gdi/salnativewidgets-luna.cxx @@ -39,6 +39,7 @@ #include #include +#include #include #include @@ -909,6 +910,28 @@ static bool ImplDrawNativeControl( HDC hDC, HTHEME hTheme, RECT rc, iState = bChecked ? TS_HOTCHECKED : TS_HOT; else iState = bChecked ? TS_CHECKED : TS_NORMAL; + + if (bUseDarkMode && GetSalInstance()->getOSVersion().startsWith(u"Windows 11") + && (bChecked + || (nState & (ControlState::PRESSED) || (nState & ControlState::ROLLOVER)))) + { + // tdf#152534 workaround bug with Windows 11 Dark theme using + // light blue as highlight color which gives insufficient + // contrast for hovered-over or pressed/checked toolbar buttons: + // manually draw background (using color a bit lighter than background + // for non-highlighted items) and draw a frame around it + ScopedHBRUSH aBgColorBrush(CreateSolidBrush(RGB(38, 38, 38))); + FillRect(hDC, &rc, aBgColorBrush.get()); + const Color aFrameColor = Application::GetSettings().GetStyleSettings().GetDisableColor(); + ScopedHBRUSH aFrameBrush(CreateSolidBrush( + RGB(aFrameColor.GetRed(), aFrameColor.GetGreen(), aFrameColor.GetBlue()))); + FrameRect(hDC, &rc, aFrameBrush.get()); + + DrawThemeText(hTheme, hDC, iPart, iState, o3tl::toW(aCaption.getStr()), -1, + DT_CENTER | DT_VCENTER | DT_SINGLELINE, 0, &rc); + return true; + } + return ImplDrawTheme( hTheme, hDC, iPart, iState, rc, aCaption); } else if( nPart == ControlPart::ThumbHorz || nPart == ControlPart::ThumbVert ) -- cgit