aboutsummaryrefslogtreecommitdiff
path: root/source/game/input/KeyboardHelper.cs
diff options
context:
space:
mode:
authorhazel <hazel@hazelthats.me>2026-01-26 22:04:39 +0100
committerhazel <hazel@hazelthats.me>2026-01-26 22:04:39 +0100
commit567c422f8cd42eba2437f9a8c2522716a1649be7 (patch)
tree93c5b296f3b7c14b626d0aadf5cad37764c41c74 /source/game/input/KeyboardHelper.cs
downloadcelesteia-567c422f8cd42eba2437f9a8c2522716a1649be7.tar.gz
celesteia-567c422f8cd42eba2437f9a8c2522716a1649be7.tar.bz2
celesteia-567c422f8cd42eba2437f9a8c2522716a1649be7.zip
celesteia archive, last updated april 9th 2024
Signed-off-by: hazel <hazel@hazelthats.me>
Diffstat (limited to 'source/game/input/KeyboardHelper.cs')
-rw-r--r--source/game/input/KeyboardHelper.cs53
1 files changed, 53 insertions, 0 deletions
diff --git a/source/game/input/KeyboardHelper.cs b/source/game/input/KeyboardHelper.cs
new file mode 100644
index 0000000..a8fd4f0
--- /dev/null
+++ b/source/game/input/KeyboardHelper.cs
@@ -0,0 +1,53 @@
+using System.Collections.Generic;
+using System.Linq;
+using Celesteia.Game.Input.Definitions;
+using Microsoft.Xna.Framework.Input;
+using MonoGame.Extended.Input;
+
+namespace Celesteia.Game.Input {
+ public static class KeyboardHelper {
+ private static KeyboardStateExtended _prev;
+ private static KeyboardStateExtended _curr;
+
+ public static void Update() {
+ _prev = _curr;
+ _curr = KeyboardExtended.GetState();
+ }
+
+ // Is any key (excluding the exemptions) down in the current state?
+ public static List<Keys> exemptedFromAny = new List<Keys> {
+ { Keys.F3 }, { Keys.F11 }
+ };
+
+ private static Keys[] pressed;
+ public static bool AnyKey() {
+ pressed = _curr.GetPressedKeys();
+ bool anyKey = pressed.Length > 0;
+
+ if (anyKey)
+ for (int i = 0; i < exemptedFromAny.Count; i++)
+ anyKey = !pressed.Contains(exemptedFromAny[i]);
+
+ return anyKey;
+ }
+
+ // Was true, now true.
+ public static bool Held(Keys keys) => _prev.IsKeyDown(keys) && _curr.IsKeyDown(keys);
+ // Is true.
+ public static bool IsDown(Keys keys) => _curr.IsKeyDown(keys);
+ // Was false, now true.
+ public static bool Pressed(Keys keys) => !_prev.IsKeyDown(keys) && _curr.IsKeyDown(keys);
+ // Was true, now false.
+ public static bool Released(Keys keys) => _prev.IsKeyDown(keys) && !_curr.IsKeyDown(keys);
+
+ public static bool Poll(Keys keys, InputPollType type) => type switch {
+ InputPollType.Held => Held(keys),
+ InputPollType.IsDown => IsDown(keys),
+ InputPollType.Pressed => Pressed(keys),
+ InputPollType.Released => Released(keys),
+ _ => false
+ };
+ }
+
+
+} \ No newline at end of file