From 91b37ae36e0cecfb6dcf02b378c93c3119fa9132 Mon Sep 17 00:00:00 2001 From: Thog Date: Sat, 15 Feb 2020 12:30:53 +0100 Subject: [PATCH] Accept gamepad inputs when not focused (#941) --- Ryujinx/Ui/GLRenderer.cs | 41 ++++++++++++++++++++-------------------- 1 file changed, 21 insertions(+), 20 deletions(-) diff --git a/Ryujinx/Ui/GLRenderer.cs b/Ryujinx/Ui/GLRenderer.cs index 6feb3ed484..591a24dfa6 100644 --- a/Ryujinx/Ui/GLRenderer.cs +++ b/Ryujinx/Ui/GLRenderer.cs @@ -323,10 +323,7 @@ namespace Ryujinx.Ui }); } - if (IsFocused) - { - UpdateFrame(); - } + UpdateFrame(); // Polling becomes expensive if it's not slept Thread.Sleep(1); @@ -351,29 +348,33 @@ namespace Ryujinx.Ui JoystickPosition rightJoystick; HLE.Input.Keyboard? hidKeyboard = null; - KeyboardState keyboard = OpenTK.Input.Keyboard.GetState(); - - Gtk.Application.Invoke(delegate - { - HandleScreenState(keyboard); - }); - int leftJoystickDx = 0; int leftJoystickDy = 0; int rightJoystickDx = 0; int rightJoystickDy = 0; - // Normal Input - currentHotkeyButtons = KeyboardControls.GetHotkeyButtons(ConfigurationState.Instance.Hid.KeyboardControls, keyboard); - currentButton = KeyboardControls.GetButtons(ConfigurationState.Instance.Hid.KeyboardControls, keyboard); - - if (ConfigurationState.Instance.Hid.EnableKeyboard) + // OpenTK always captures keyboard events, even if out of focus, so check if window is focused. + if (IsFocused) { - hidKeyboard = KeyboardControls.GetKeysDown(ConfigurationState.Instance.Hid.KeyboardControls, keyboard); - } + KeyboardState keyboard = OpenTK.Input.Keyboard.GetState(); - (leftJoystickDx, leftJoystickDy) = KeyboardControls.GetLeftStick(ConfigurationState.Instance.Hid.KeyboardControls, keyboard); - (rightJoystickDx, rightJoystickDy) = KeyboardControls.GetRightStick(ConfigurationState.Instance.Hid.KeyboardControls, keyboard); + Gtk.Application.Invoke(delegate + { + HandleScreenState(keyboard); + }); + + // Normal Input + currentHotkeyButtons = KeyboardControls.GetHotkeyButtons(ConfigurationState.Instance.Hid.KeyboardControls, keyboard); + currentButton = KeyboardControls.GetButtons(ConfigurationState.Instance.Hid.KeyboardControls, keyboard); + + if (ConfigurationState.Instance.Hid.EnableKeyboard) + { + hidKeyboard = KeyboardControls.GetKeysDown(ConfigurationState.Instance.Hid.KeyboardControls, keyboard); + } + + (leftJoystickDx, leftJoystickDy) = KeyboardControls.GetLeftStick(ConfigurationState.Instance.Hid.KeyboardControls, keyboard); + (rightJoystickDx, rightJoystickDy) = KeyboardControls.GetRightStick(ConfigurationState.Instance.Hid.KeyboardControls, keyboard); + } if (!hidKeyboard.HasValue) {