From 265b4544effd6fbb24527c466e84ef0b70e7bea8 Mon Sep 17 00:00:00 2001 From: Geoffrey McRae Date: Fri, 4 Dec 2020 01:40:29 +1100 Subject: [PATCH] [client] spice: adjust ordering to avoid dropping mouse input events --- client/src/main.c | 41 +++++++++++++++++++---------------------- 1 file changed, 19 insertions(+), 22 deletions(-) diff --git a/client/src/main.c b/client/src/main.c index 1b75f9d2..8f1cd58a 100644 --- a/client/src/main.c +++ b/client/src/main.c @@ -795,16 +795,6 @@ static void warpMouse(int x, int y) static void handleMouseMoveEvent(int ex, int ey) { - if (!state.cursorInWindow) - return; - - if (state.ignoreInput || !params.useSpiceInput) - return; - - state.curLocalX = ex; - state.curLocalY = ey; - state.haveCurLocal = true; - SDL_Point delta = { .x = ex - state.curLastX, .y = ey - state.curLastY @@ -813,8 +803,9 @@ static void handleMouseMoveEvent(int ex, int ey) if (delta.x == 0 && delta.y == 0) return; - state.curLastX = ex; - state.curLastY = ey; + state.curLastX = state.curLocalX = ex; + state.curLastY = state.curLocalX = ey; + state.haveCurLocal = true; if (state.warpState == WARP_STATE_ACTIVE && ex == state.warpToX && ey == state.warpToY) @@ -823,21 +814,20 @@ static void handleMouseMoveEvent(int ex, int ey) return; } - if (!state.cursorInWindow) + if (!state.cursorInWindow || state.ignoreInput || !params.useSpiceInput) return; - if ((state.haveCursorPos || state.grabMouse) && - (ex < 100 || ex > state.windowW - 100 || - ey < 100 || ey > state.windowH - 100)) - { - warpMouse(state.windowW / 2, state.windowH / 2); - return; - } - /* if we don't have the current cursor pos just send cursor movements */ if (!state.haveCursorPos) { + state.cursorInView = true; spice_mouse_motion(delta.x, delta.y); + if ((state.haveCursorPos || state.grabMouse) && + (ex < 100 || ex > state.windowW - 100 || + ey < 100 || ey > state.windowH - 100)) + { + warpMouse(state.windowW / 2, state.windowH / 2); + } return; } @@ -851,7 +841,6 @@ static void handleMouseMoveEvent(int ex, int ey) if (params.useSpiceInput && !params.alwaysShowCursor) state.drawCursor = false; - return; } if (!state.cursorInView) @@ -881,6 +870,14 @@ static void handleMouseMoveEvent(int ex, int ey) state.sensY -= delta.y; } + if ((state.haveCursorPos || state.grabMouse) && + (ex < 100 || ex > state.windowW - 100 || + ey < 100 || ey > state.windowH - 100)) + { + warpMouse(state.windowW / 2, state.windowH / 2); + return; + } + if (!state.grabMouse && state.warpState == WARP_STATE_ON) { /* check if the movement would exit the window */