hook EnumDisplaySettingsA
This commit is contained in:
parent
e19d896dab
commit
4385f77b52
5 changed files with 40 additions and 2 deletions
|
@ -50,6 +50,7 @@ SETWINDOWSHOOKEXAPROC real_SetWindowsHookExA = SetWindowsHookExA;
|
|||
PEEKMESSAGEAPROC real_PeekMessageA = PeekMessageA;
|
||||
GETMESSAGEAPROC real_GetMessageA = GetMessageA;
|
||||
GETWINDOWPLACEMENTPROC real_GetWindowPlacement = GetWindowPlacement;
|
||||
ENUMDISPLAYSETTINGSAPROC real_EnumDisplaySettingsA = EnumDisplaySettingsA;
|
||||
GETKEYSTATEPROC real_GetKeyState = GetKeyState;
|
||||
GETASYNCKEYSTATEPROC real_GetAsyncKeyState = GetAsyncKeyState;
|
||||
GETDEVICECAPSPROC real_GetDeviceCaps = GetDeviceCaps;
|
||||
|
@ -98,6 +99,7 @@ HOOKLIST g_hook_hooklist[] =
|
|||
{ "PeekMessageA", (PROC)fake_PeekMessageA, (PROC*)&real_PeekMessageA, 0 },
|
||||
{ "GetMessageA", (PROC)fake_GetMessageA, (PROC*)&real_GetMessageA, 0 },
|
||||
{ "GetWindowPlacement", (PROC)fake_GetWindowPlacement, (PROC*)&real_GetWindowPlacement, 0 },
|
||||
{ "EnumDisplaySettingsA", (PROC)fake_EnumDisplaySettingsA, (PROC*)&real_EnumDisplaySettingsA, 0 },
|
||||
{ "GetKeyState", (PROC)fake_GetKeyState, (PROC*)&real_GetKeyState, 0 },
|
||||
{ "GetAsyncKeyState", (PROC)fake_GetAsyncKeyState, (PROC*)&real_GetAsyncKeyState, 0 },
|
||||
{ "SetForegroundWindow", (PROC)fake_SetForegroundWindow, (PROC*)&real_SetForegroundWindow, 0 },
|
||||
|
|
|
@ -767,6 +767,39 @@ BOOL WINAPI fake_GetWindowPlacement(HWND hWnd, WINDOWPLACEMENT* lpwndpl)
|
|||
return result;
|
||||
}
|
||||
|
||||
BOOL WINAPI fake_EnumDisplaySettingsA(LPCSTR lpszDeviceName, DWORD iModeNum, DEVMODEA* lpDevMode)
|
||||
{
|
||||
BOOL result = real_EnumDisplaySettingsA(lpszDeviceName, iModeNum, lpDevMode);
|
||||
|
||||
if (result && !lpszDeviceName && lpDevMode && iModeNum == ENUM_CURRENT_SETTINGS)
|
||||
{
|
||||
if (g_ddraw.ref && g_ddraw.width)
|
||||
{
|
||||
lpDevMode->dmPelsWidth = g_ddraw.width;
|
||||
lpDevMode->dmPelsHeight = g_ddraw.height;
|
||||
lpDevMode->dmBitsPerPel = g_ddraw.bpp;
|
||||
}
|
||||
else if (g_config.fake_mode[0])
|
||||
{
|
||||
char* e = &g_config.fake_mode[0];
|
||||
|
||||
lpDevMode->dmPelsWidth = strtoul(e, &e, 0);
|
||||
lpDevMode->dmPelsHeight = strtoul(e + 1, &e, 0);
|
||||
lpDevMode->dmBitsPerPel = strtoul(e + 1, &e, 0);
|
||||
}
|
||||
else
|
||||
{
|
||||
lpDevMode->dmPelsWidth = 1024;
|
||||
lpDevMode->dmPelsHeight = 768;
|
||||
lpDevMode->dmBitsPerPel = 16;
|
||||
}
|
||||
|
||||
lpDevMode->dmDisplayFrequency = 60;
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
SHORT WINAPI fake_GetKeyState(int nVirtKey)
|
||||
{
|
||||
if (g_config.windowed && g_ddraw.ref && g_ddraw.hwnd && !util_in_foreground())
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue