[client] dont show the pointer at launch unless it really should be

This commit is contained in:
Geoffrey McRae 2021-01-19 06:00:59 +11:00
parent b2ac2980d5
commit 6005006dd4

View file

@ -92,7 +92,7 @@ static void lgInit(void)
g_cursor.useScale = false; g_cursor.useScale = false;
g_cursor.scale.x = 1.0; g_cursor.scale.x = 1.0;
g_cursor.scale.y = 1.0; g_cursor.scale.y = 1.0;
g_cursor.draw = true; g_cursor.draw = false;
g_cursor.inView = false; g_cursor.inView = false;
g_cursor.guest.valid = false; g_cursor.guest.valid = false;
} }
@ -902,21 +902,22 @@ void spiceClipboardRequest(const SpiceDataType type)
g_state.ds->cbRequest(spice_type_to_clipboard_type(type)); g_state.ds->cbRequest(spice_type_to_clipboard_type(type));
} }
static void warpPointer(int x, int y, bool exiting) static bool warpPointer(int x, int y, bool exiting)
{ {
if (!g_cursor.inWindow) if (!g_cursor.inWindow)
return; return false;
if (g_cursor.warpState == WARP_STATE_OFF) if (g_cursor.warpState == WARP_STATE_OFF)
return; return false;
if (exiting) if (exiting)
g_cursor.warpState = WARP_STATE_OFF; g_cursor.warpState = WARP_STATE_OFF;
if (g_cursor.pos.x == x && g_cursor.pos.y == y) if (g_cursor.pos.x == x && g_cursor.pos.y == y)
return; return true;
g_state.ds->warpPointer(x, y, exiting); g_state.ds->warpPointer(x, y, exiting);
return true;
} }
static bool isValidCursorLocation(int x, int y) static bool isValidCursorLocation(int x, int y)
@ -1574,7 +1575,8 @@ int eventFilter(void * userdata, SDL_Event * event)
struct DoublePoint local; struct DoublePoint local;
if (guestCurToLocal(&local)) if (guestCurToLocal(&local))
warpPointer(round(local.x), round(local.y), false); if (warpPointer(round(local.x), round(local.y), false))
setCursorInView(true);
break; break;
} }
} }