From a46e464003b081a617f2d7964d0ca112115b80b4 Mon Sep 17 00:00:00 2001 From: Isaac Marovitz Date: Wed, 28 Feb 2024 12:58:26 -0500 Subject: [PATCH] feat: recognize keyboard keys as "pressed" only after key up occurred Co-authored-by: Nico --- .../Assigner/KeyboardKeyAssigner.cs | 29 +++++++++++++------ 1 file changed, 20 insertions(+), 9 deletions(-) diff --git a/src/Ryujinx.Input/Assigner/KeyboardKeyAssigner.cs b/src/Ryujinx.Input/Assigner/KeyboardKeyAssigner.cs index 0f1db63dd..301302d3f 100644 --- a/src/Ryujinx.Input/Assigner/KeyboardKeyAssigner.cs +++ b/src/Ryujinx.Input/Assigner/KeyboardKeyAssigner.cs @@ -6,7 +6,7 @@ namespace Ryujinx.Input.Assigner public class KeyboardKeyAssigner : IButtonAssigner { private readonly IKeyboard _keyboard; - + private ButtonValue? _pressedKey; private KeyboardStateSnapshot _keyboardState; public KeyboardKeyAssigner(IKeyboard keyboard) @@ -14,16 +14,26 @@ namespace Ryujinx.Input.Assigner _keyboard = keyboard; } - public void Initialize() { } + public void Initialize() + { + _pressedKey = null; + } public void ReadInput() { - _keyboardState = _keyboard.GetKeyboardStateSnapshot(); + var newKeyboardState = _keyboard.GetKeyboardStateSnapshot(); + + if (_keyboardState != null) + { + DetectPressedKeys(_keyboardState, newKeyboardState); + } + + _keyboardState = newKeyboardState; } public bool HasAnyButtonPressed() { - return GetPressedButton() is not null; + return _pressedKey != null; } public bool ShouldCancel() @@ -33,18 +43,19 @@ namespace Ryujinx.Input.Assigner public ButtonValue? GetPressedButton() { - ButtonValue? keyPressed = null; + return !ShouldCancel() && HasAnyButtonPressed() ? _pressedKey : null; + } + public void DetectPressedKeys(KeyboardStateSnapshot oldState, KeyboardStateSnapshot newState) + { for (Key key = Key.Unknown; key < Key.Count; key++) { - if (_keyboardState.IsPressed(key)) + if (oldState.IsPressed(key) && !newState.IsPressed(key)) { - keyPressed = new(key); + _pressedKey = new(key); break; } } - - return !ShouldCancel() ? keyPressed : null; } } }