From faa16b207c198f7e1c76f2d18c67ab7540ab7031 Mon Sep 17 00:00:00 2001 From: Cameron Gutman Date: Sat, 14 Mar 2020 00:33:53 -0700 Subject: [PATCH] Implement a more reliable mouse capture workaround for GNOME+Wayland --- app/streaming/session.cpp | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/app/streaming/session.cpp b/app/streaming/session.cpp index 77d120fb..5dad02a7 100644 --- a/app/streaming/session.cpp +++ b/app/streaming/session.cpp @@ -1076,19 +1076,21 @@ void Session::exec(int displayOriginX, int displayOriginY) SDL_SetWindowFullscreen(m_Window, m_FullScreenFlag); } + bool needsFirstEnterCapture = false; + #ifndef QT_DEBUG // Capture the mouse by default on release builds only. // This prevents the mouse from becoming trapped inside // Moonlight when it's halted at a debug break. if (m_Preferences->windowMode != StreamingPreferences::WM_WINDOWED) { -#if !SDL_VERSION_ATLEAST(2, 0, 11) - // HACK: This doesn't work on Wayland until we render a frame, so - // just don't do it for now. This bug is fixed in SDL 2.0.11. - if (strcmp(SDL_GetCurrentVideoDriver(), "wayland") != 0) -#endif - { + // HACK: For Wayland, we wait until we get the first SDL_WINDOWEVENT_ENTER + // event where it seems to work consistently on GNOME. + if (strcmp(SDL_GetCurrentVideoDriver(), "wayland") != 0) { m_InputHandler->setCaptureActive(true); } + else { + needsFirstEnterCapture = true; + } } #endif @@ -1190,6 +1192,12 @@ void Session::exec(int displayOriginX, int displayOriginY) m_InputHandler->raiseAllKeys(); } + // Capture the mouse on SDL_WINDOWEVENT_ENTER if needed + if (needsFirstEnterCapture && event.window.event == SDL_WINDOWEVENT_ENTER) { + m_InputHandler->setCaptureActive(true); + needsFirstEnterCapture = false; + } + // We want to recreate the decoder for resizes (full-screen toggles) and the initial shown event. // We use SDL_WINDOWEVENT_SIZE_CHANGED rather than SDL_WINDOWEVENT_RESIZED because the latter doesn't // seem to fire when switching from windowed to full-screen on X11.