From 6277a6c41cd3e1779e86fd900e8349189d765305 Mon Sep 17 00:00:00 2001 From: "C. S." <76898260+Pentalimbed@users.noreply.github.com> Date: Fri, 9 Aug 2024 14:53:15 +0100 Subject: [PATCH] fix: alt+tab input sticking (#403) --- src/Hooks.cpp | 22 +++++++--------------- 1 file changed, 7 insertions(+), 15 deletions(-) diff --git a/src/Hooks.cpp b/src/Hooks.cpp index 9198417c3..966a9150c 100644 --- a/src/Hooks.cpp +++ b/src/Hooks.cpp @@ -308,7 +308,7 @@ namespace Hooks { static LRESULT thunk(HWND a_hwnd, UINT a_msg, WPARAM a_wParam, LPARAM a_lParam) { - if (a_msg == WM_KILLFOCUS) { + if (a_msg == WM_KILLFOCUS || a_msg == WM_SETFOCUS) { Menu::GetSingleton()->OnFocusLost(); auto& io = ImGui::GetIO(); io.ClearInputKeys(); @@ -316,19 +316,7 @@ namespace Hooks } return func(a_hwnd, a_msg, a_wParam, a_lParam); } - static inline REL::Relocation func; - }; - - struct RegisterClassA_Hook - { - static ATOM thunk(WNDCLASSA* a_wndClass) - { - WndProcHandler_Hook::func = reinterpret_cast(a_wndClass->lpfnWndProc); - a_wndClass->lpfnWndProc = &WndProcHandler_Hook::thunk; - - return func(a_wndClass); - } - static inline REL::Relocation func; + static inline WNDPROC func; }; struct CreateRenderTarget_Main @@ -473,7 +461,11 @@ namespace Hooks stl::write_thunk_call(REL::RelocationID(75595, 77226).address() + REL::Relocate(0x50, 0x2BC)); logger::info("Hooking WndProcHandler"); - stl::write_thunk_call_6(REL::VariantID(75591, 77226, 0xDC4B90).address() + REL::VariantOffset(0x8E, 0x15C, 0x99).offset()); + WndProcHandler_Hook::func = reinterpret_cast( + SetWindowLongPtrA( + RE::BSGraphics::Renderer::GetSingleton()->GetRuntimeData().renderWindows[0].hWnd, + GWLP_WNDPROC, + reinterpret_cast(WndProcHandler_Hook::thunk))); //logger::info("Hooking D3D11CreateDeviceAndSwapChain"); //*(FARPROC*)&ptrD3D11CreateDeviceAndSwapChain = GetProcAddress(GetModuleHandleA("d3d11.dll"), "D3D11CreateDeviceAndSwapChain");