adjust peek/getmessage hooks
This commit is contained in:
parent
6e3a6207da
commit
188ef913c3
1 changed files with 55 additions and 5 deletions
|
@ -701,7 +701,9 @@ BOOL HandleMessage(LPMSG lpMsg, HWND hWnd, UINT wMsgFilterMin, UINT wMsgFilterMa
|
||||||
InterlockedExchange((LONG*)&g_ddraw.cursor.y, y);
|
InterlockedExchange((LONG*)&g_ddraw.cursor.y, y);
|
||||||
|
|
||||||
lpMsg->lParam = MAKELPARAM(x, y);
|
lpMsg->lParam = MAKELPARAM(x, y);
|
||||||
fake_GetCursorPos(&lpMsg->pt);
|
|
||||||
|
lpMsg->pt.x = x;
|
||||||
|
lpMsg->pt.y = y;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -716,8 +718,32 @@ BOOL WINAPI fake_GetMessageA(LPMSG lpMsg, HWND hWnd, UINT wMsgFilterMin, UINT wM
|
||||||
{
|
{
|
||||||
BOOL result = real_GetMessageA(lpMsg, hWnd, wMsgFilterMin, wMsgFilterMax);
|
BOOL result = real_GetMessageA(lpMsg, hWnd, wMsgFilterMin, wMsgFilterMax);
|
||||||
|
|
||||||
if (result && g_config.hook_getmessage)
|
if (result && g_ddraw.ref && g_ddraw.hwnd && g_ddraw.width)
|
||||||
|
{
|
||||||
|
if (g_config.hook_getmessage)
|
||||||
|
{
|
||||||
HandleMessage(lpMsg, hWnd, wMsgFilterMin, wMsgFilterMax);
|
HandleMessage(lpMsg, hWnd, wMsgFilterMin, wMsgFilterMax);
|
||||||
|
}
|
||||||
|
else if (g_mouse_locked && (!g_config.windowed || real_ScreenToClient(g_ddraw.hwnd, &lpMsg->pt)))
|
||||||
|
{
|
||||||
|
int x = max(lpMsg->pt.x - g_ddraw.mouse.x_adjust, 0);
|
||||||
|
int y = max(lpMsg->pt.y - g_ddraw.mouse.y_adjust, 0);
|
||||||
|
|
||||||
|
if (g_config.adjmouse)
|
||||||
|
{
|
||||||
|
x = (DWORD)(roundf(x * g_ddraw.mouse.unscale_x));
|
||||||
|
y = (DWORD)(roundf(y * g_ddraw.mouse.unscale_y));
|
||||||
|
}
|
||||||
|
|
||||||
|
lpMsg->pt.x = min(x, g_ddraw.width - 1);
|
||||||
|
lpMsg->pt.y = min(y, g_ddraw.height - 1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
lpMsg->pt.x = InterlockedExchangeAdd((LONG*)&g_ddraw.cursor.x, 0);
|
||||||
|
lpMsg->pt.y = InterlockedExchangeAdd((LONG*)&g_ddraw.cursor.y, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -726,8 +752,32 @@ BOOL WINAPI fake_PeekMessageA(LPMSG lpMsg, HWND hWnd, UINT wMsgFilterMin, UINT w
|
||||||
{
|
{
|
||||||
BOOL result = real_PeekMessageA(lpMsg, hWnd, wMsgFilterMin, wMsgFilterMax, wRemoveMsg);
|
BOOL result = real_PeekMessageA(lpMsg, hWnd, wMsgFilterMin, wMsgFilterMax, wRemoveMsg);
|
||||||
|
|
||||||
if (result && g_config.hook_peekmessage)
|
if (result && g_ddraw.ref && g_ddraw.hwnd && g_ddraw.width)
|
||||||
|
{
|
||||||
|
if (g_config.hook_peekmessage)
|
||||||
|
{
|
||||||
HandleMessage(lpMsg, hWnd, wMsgFilterMin, wMsgFilterMax);
|
HandleMessage(lpMsg, hWnd, wMsgFilterMin, wMsgFilterMax);
|
||||||
|
}
|
||||||
|
else if (g_mouse_locked && (!g_config.windowed || real_ScreenToClient(g_ddraw.hwnd, &lpMsg->pt)))
|
||||||
|
{
|
||||||
|
int x = max(lpMsg->pt.x - g_ddraw.mouse.x_adjust, 0);
|
||||||
|
int y = max(lpMsg->pt.y - g_ddraw.mouse.y_adjust, 0);
|
||||||
|
|
||||||
|
if (g_config.adjmouse)
|
||||||
|
{
|
||||||
|
x = (DWORD)(roundf(x * g_ddraw.mouse.unscale_x));
|
||||||
|
y = (DWORD)(roundf(y * g_ddraw.mouse.unscale_y));
|
||||||
|
}
|
||||||
|
|
||||||
|
lpMsg->pt.x = min(x, g_ddraw.width - 1);
|
||||||
|
lpMsg->pt.y = min(y, g_ddraw.height - 1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
lpMsg->pt.x = InterlockedExchangeAdd((LONG*)&g_ddraw.cursor.x, 0);
|
||||||
|
lpMsg->pt.y = InterlockedExchangeAdd((LONG*)&g_ddraw.cursor.y, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue