From 63852dc7110ad4e3264b02784bc2a8cb1c64403a Mon Sep 17 00:00:00 2001 From: Michael Maltsev <4129781+m417z@users.noreply.github.com> Date: Sat, 11 Nov 2023 01:19:31 +0200 Subject: [PATCH] Taskbar height and icon size v1.2.1 * Fixed displaced clock on secondary monitors. --- mods/taskbar-icon-size.wh.cpp | 58 +++++++++++++++++++++++++++++++---- 1 file changed, 52 insertions(+), 6 deletions(-) diff --git a/mods/taskbar-icon-size.wh.cpp b/mods/taskbar-icon-size.wh.cpp index 0f9262619..a8ed4189f 100644 --- a/mods/taskbar-icon-size.wh.cpp +++ b/mods/taskbar-icon-size.wh.cpp @@ -2,7 +2,7 @@ // @id taskbar-icon-size // @name Taskbar height and icon size // @description Control the taskbar height and icon size, improve icon quality (Windows 11 only) -// @version 1.2 +// @version 1.2.1 // @author m417z // @github https://github.com/m417z // @twitter https://twitter.com/m417z @@ -98,6 +98,7 @@ std::atomic g_unloading = false; int g_originalTaskbarHeight; int g_taskbarHeight; +bool g_inSystemTraySecondaryController_UpdateFrameSize; double* double_48_value_Original; @@ -124,16 +125,15 @@ ResourceDictionary_Lookup_Hook(void* pThis, return ret; } - auto valueDouble = - ret->try_as>(); + auto valueDouble = ret->try_as(); if (!valueDouble) { return ret; } double newValueDouble = g_settings.taskbarButtonWidth; - if (newValueDouble != valueDouble.Value()) { - Wh_Log(L"Overriding value %s: %f->%f", keyString->c_str(), - valueDouble.Value(), newValueDouble); + if (newValueDouble != *valueDouble) { + Wh_Log(L"Overriding value %s: %f->%f", keyString->c_str(), *valueDouble, + newValueDouble); *ret = winrt::box_value(newValueDouble); } @@ -281,6 +281,34 @@ void WINAPI TaskbarFrame_Height_double_Hook(void* pThis, double value) { return TaskbarFrame_Height_double_Original(pThis, value); } +using SystemTraySecondaryController_UpdateFrameSize_t = + void(WINAPI*)(void* pThis); +SystemTraySecondaryController_UpdateFrameSize_t + SystemTraySecondaryController_UpdateFrameSize_Original; +void WINAPI SystemTraySecondaryController_UpdateFrameSize_Hook(void* pThis) { + Wh_Log(L">"); + + g_inSystemTraySecondaryController_UpdateFrameSize = true; + + SystemTraySecondaryController_UpdateFrameSize_Original(pThis); + + g_inSystemTraySecondaryController_UpdateFrameSize = false; +} + +using SystemTrayFrame_Height_t = void(WINAPI*)(void* pThis, double value); +SystemTrayFrame_Height_t SystemTrayFrame_Height_Original; +void WINAPI SystemTrayFrame_Height_Hook(void* pThis, double value) { + // Wh_Log(L">"); + + if (g_inSystemTraySecondaryController_UpdateFrameSize) { + // Set the secondary taskbar clock height to NaN, otherwise it may not + // match the custom taskbar height. + value = std::numeric_limits::quiet_NaN(); + } + + SystemTrayFrame_Height_Original(pThis, value); +} + using SHAppBarMessage_t = decltype(&SHAppBarMessage); SHAppBarMessage_t SHAppBarMessage_Original; auto WINAPI SHAppBarMessage_Hook(DWORD dwMessage, PAPPBARDATA pData) { @@ -733,6 +761,24 @@ bool HookTaskbarViewDllSymbols(HMODULE module) { (void**)&TaskbarFrame_Height_double_Original, (void*)TaskbarFrame_Height_double_Hook, }, + { + { + LR"(private: void __cdecl winrt::SystemTray::implementation::SystemTraySecondaryController::UpdateFrameSize(void))", + LR"(private: void __cdecl winrt::SystemTray::implementation::SystemTraySecondaryController::UpdateFrameSize(void) __ptr64)", + }, + (void**)&SystemTraySecondaryController_UpdateFrameSize_Original, + (void*)SystemTraySecondaryController_UpdateFrameSize_Hook, + true, + }, + { + { + LR"(public: __cdecl winrt::impl::consume_Windows_UI_Xaml_IFrameworkElement::Height(double)const )", + LR"(public: __cdecl winrt::impl::consume_Windows_UI_Xaml_IFrameworkElement::Height(double)const __ptr64)", + }, + (void**)&SystemTrayFrame_Height_Original, + (void*)SystemTrayFrame_Height_Hook, + true, + }, }; return HookSymbols(module, symbolHooks, ARRAYSIZE(symbolHooks));