dinput: Only call SetCursorPos if ClipCursor fails.

Fixes mouse sometimes jumping around in Mechwarrior Online on
KDE/Wayland.
This commit is contained in:
Rémi Bernon 2023-09-08 19:26:51 +02:00 committed by Alexandre Julliard
parent b1e54a5f04
commit 6ac127ebc6
Notes: Alexandre Julliard 2024-11-18 23:18:33 +01:00
Approved-by: Alexandre Julliard (@julliard)
Merge-Request: https://gitlab.winehq.org/wine/wine/merge_requests/6833

View file

@ -313,13 +313,6 @@ static void warp_check( struct mouse *impl, BOOL force )
impl->need_warp = FALSE; impl->need_warp = FALSE;
if (!GetClientRect( impl->base.win, &rect )) return; if (!GetClientRect( impl->base.win, &rect )) return;
MapWindowPoints( impl->base.win, 0, (POINT *)&rect, 2 ); MapWindowPoints( impl->base.win, 0, (POINT *)&rect, 2 );
if (!impl->clipped)
{
mapped_center.x = (rect.left + rect.right) / 2;
mapped_center.y = (rect.top + rect.bottom) / 2;
TRACE( "Warping mouse to x %+ld, y %+ld.\n", mapped_center.x, mapped_center.y );
SetCursorPos( mapped_center.x, mapped_center.y );
}
if (impl->base.dwCoopLevel & DISCL_EXCLUSIVE) if (impl->base.dwCoopLevel & DISCL_EXCLUSIVE)
{ {
/* make sure we clip even if the window covers the whole screen */ /* make sure we clip even if the window covers the whole screen */
@ -330,6 +323,13 @@ static void warp_check( struct mouse *impl, BOOL force )
TRACE("Clipping mouse to %s\n", wine_dbgstr_rect( &rect )); TRACE("Clipping mouse to %s\n", wine_dbgstr_rect( &rect ));
impl->clipped = ClipCursor( &rect ); impl->clipped = ClipCursor( &rect );
} }
if (!impl->clipped)
{
mapped_center.x = (rect.left + rect.right) / 2;
mapped_center.y = (rect.top + rect.bottom) / 2;
TRACE( "Warping mouse to x %+ld, y %+ld.\n", mapped_center.x, mapped_center.y );
SetCursorPos( mapped_center.x, mapped_center.y );
}
} }
} }