|
|
@ -262,6 +262,24 @@ plKeyDef plInputManager::UntranslateKey(plKeyDef key, hsBool extended) |
|
|
|
|
|
|
|
|
|
|
|
return key; |
|
|
|
return key; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
#if HS_BUILD_FOR_WIN32 |
|
|
|
|
|
|
|
/** Determines if we need to hackily flush cursor updates
|
|
|
|
|
|
|
|
* \remarks Normally, we would just call SetCursorPos directly. However, in Windows 10's |
|
|
|
|
|
|
|
* 2017 Fall Creator's Update, SetCursorPos, GetCursorPos, and WM_MOUSEMOVE are buggy. |
|
|
|
|
|
|
|
* Research done by Deledrius matches my independent observations and failed fixes: |
|
|
|
|
|
|
|
* https://discourse.libsdl.org/t/win10-fall-creators-update-breaks-mouse-warping/23526
|
|
|
|
|
|
|
|
* Many thanks to these fine folks who work on libsdl! |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
static bool INeedsWin10CursorHack() |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
// According to Chromium, Microsoft will be fixing the cursor bug in the next build
|
|
|
|
|
|
|
|
// of Windows 10, so we only need to test for the dreaded 2017 FCU...
|
|
|
|
|
|
|
|
// Reference: https://bugs.chromium.org/p/chromium/issues/detail?id=781182#c15
|
|
|
|
|
|
|
|
const RTL_OSVERSIONINFOW& version = hsGetWindowsVersion(); |
|
|
|
|
|
|
|
return version.dwMajorVersion == 10 && version.dwBuildNumber == 16299; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif // HS_BUILD_FOR_WIN32
|
|
|
|
|
|
|
|
|
|
|
|
void plInputManager::HandleWin32ControlEvent(UINT message, WPARAM Wparam, LPARAM Lparam, HWND hWnd) |
|
|
|
void plInputManager::HandleWin32ControlEvent(UINT message, WPARAM Wparam, LPARAM Lparam, HWND hWnd) |
|
|
|
{ |
|
|
|
{ |
|
|
@ -378,6 +396,12 @@ void plInputManager::HandleWin32ControlEvent(UINT message, WPARAM Wparam, LPARAM |
|
|
|
{
|
|
|
|
{
|
|
|
|
pt.x = (rect.right - rect.left) / 2; |
|
|
|
pt.x = (rect.right - rect.left) / 2; |
|
|
|
pt.y = HIWORD(Lparam); |
|
|
|
pt.y = HIWORD(Lparam); |
|
|
|
|
|
|
|
if (INeedsWin10CursorHack()) { |
|
|
|
|
|
|
|
pXMsg->fWx = pt.x; |
|
|
|
|
|
|
|
pXMsg->fX = pt.x / (float)rect.right; |
|
|
|
|
|
|
|
for (int i = 0; i < fInputDevices.Count(); i++) |
|
|
|
|
|
|
|
fInputDevices[i]->MsgReceive(pXMsg); |
|
|
|
|
|
|
|
} |
|
|
|
ClientToScreen(hWnd, &pt); |
|
|
|
ClientToScreen(hWnd, &pt); |
|
|
|
SetCursorPos( pt.x, pt.y ); |
|
|
|
SetCursorPos( pt.x, pt.y ); |
|
|
|
} |
|
|
|
} |
|
|
@ -386,6 +410,13 @@ void plInputManager::HandleWin32ControlEvent(UINT message, WPARAM Wparam, LPARAM |
|
|
|
{
|
|
|
|
{
|
|
|
|
pt.y = (rect.bottom - rect.top) / 2; |
|
|
|
pt.y = (rect.bottom - rect.top) / 2; |
|
|
|
pt.x = LOWORD(Lparam); |
|
|
|
pt.x = LOWORD(Lparam); |
|
|
|
|
|
|
|
if (INeedsWin10CursorHack()) { |
|
|
|
|
|
|
|
pYMsg->fWy = pt.y; |
|
|
|
|
|
|
|
pYMsg->fY = pYMsg->fWy / (float)rect.bottom; |
|
|
|
|
|
|
|
for (int i = 0; i < fInputDevices.Count(); i++) |
|
|
|
|
|
|
|
fInputDevices[i]->MsgReceive(pYMsg); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
ClientToScreen(hWnd, &pt); |
|
|
|
ClientToScreen(hWnd, &pt); |
|
|
|
SetCursorPos( pt.x, pt.y ); |
|
|
|
SetCursorPos( pt.x, pt.y ); |
|
|
|
} |
|
|
|
} |
|
|
@ -393,6 +424,17 @@ void plInputManager::HandleWin32ControlEvent(UINT message, WPARAM Wparam, LPARAM |
|
|
|
{ |
|
|
|
{ |
|
|
|
pt.y = (rect.bottom - rect.top) / 2; |
|
|
|
pt.y = (rect.bottom - rect.top) / 2; |
|
|
|
pt.x = (rect.right - rect.left) / 2; |
|
|
|
pt.x = (rect.right - rect.left) / 2; |
|
|
|
|
|
|
|
if (INeedsWin10CursorHack()) { |
|
|
|
|
|
|
|
pXMsg->fWx = pt.x; |
|
|
|
|
|
|
|
pXMsg->fX = pXMsg->fWx / (float)rect.right; |
|
|
|
|
|
|
|
pYMsg->fWy = pt.y; |
|
|
|
|
|
|
|
pYMsg->fY = pYMsg->fWy / (float)rect.bottom; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (int i = 0; i < fInputDevices.Count(); i++) { |
|
|
|
|
|
|
|
fInputDevices[i]->MsgReceive(pXMsg); |
|
|
|
|
|
|
|
fInputDevices[i]->MsgReceive(pYMsg); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
ClientToScreen(hWnd, &pt); |
|
|
|
ClientToScreen(hWnd, &pt); |
|
|
|
SetCursorPos( pt.x, pt.y ); |
|
|
|
SetCursorPos( pt.x, pt.y ); |
|
|
|
} |
|
|
|
} |
|
|
|