aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLibravatar Silas Bartha <silas@exvacuum.dev>2024-07-31 11:44:07 -0400
committerLibravatar Silas Bartha <silas@exvacuum.dev>2024-07-31 11:44:07 -0400
commitef0771d67ca4b50a10c140ec8fb6bd24f05958d6 (patch)
tree95dc1a9c361ebfb01ef0c65d2c4756b657ff8b20 /src
parent72da32574eea22921da0fb9e7affb1e0f8a3c57f (diff)
Add "just pressed" input trackingv0.4.0
Diffstat (limited to 'src')
-rw-r--r--src/input/resources.rs40
-rw-r--r--src/input/systems.rs5
2 files changed, 26 insertions, 19 deletions
diff --git a/src/input/resources.rs b/src/input/resources.rs
index afe6353..ba2f6dd 100644
--- a/src/input/resources.rs
+++ b/src/input/resources.rs
@@ -1,4 +1,4 @@
-use bevy::{prelude::*, utils::HashSet};
+use bevy::{prelude:: *, utils::HashSet};
use crossterm::event::{Event, KeyCode};
use std::sync::{Arc, Mutex};
@@ -6,7 +6,8 @@ use std::sync::{Arc, Mutex};
#[derive(Resource, Default)]
pub struct TerminalInput {
pressed_keys: HashSet<KeyCode>,
- released_keys: HashSet<KeyCode>,
+ just_pressed_keys: HashSet<KeyCode>,
+ just_released_keys: HashSet<KeyCode>,
}
impl TerminalInput {
@@ -15,31 +16,36 @@ impl TerminalInput {
self.pressed_keys.contains(&code)
}
- /// Gets whether the given key is released
- pub fn is_released(&self, code: KeyCode) -> bool {
- self.released_keys.contains(&code)
+ /// Gets whether the given key was just pressed
+ pub fn just_pressed(&self, code: KeyCode) -> bool {
+ self.just_pressed_keys.contains(&code)
+ }
+
+ /// Gets whether the given key was just released
+ pub fn just_released(&self, code: KeyCode) -> bool {
+ self.just_released_keys.contains(&code)
}
/// Sets given key to pressed
pub(super) fn press(&mut self, code: KeyCode) {
- if !self.is_pressed(code) {
- self.pressed_keys.insert(code);
- }
+ self.pressed_keys.insert(code);
+ self.just_pressed_keys.insert(code);
}
/// Sets given key to released and removes pressed state
pub(super) fn release(&mut self, code: KeyCode) {
- if self.is_pressed(code) {
- self.pressed_keys.remove(&code);
- }
- if !self.is_released(code) {
- self.released_keys.insert(code);
- }
+ self.pressed_keys.remove(&code);
+ self.just_released_keys.insert(code);
}
- /// Clears all released keys
- pub(super) fn clear_released(&mut self) {
- self.released_keys.clear();
+ /// Clears all just released keys
+ pub(super) fn clear_just_released(&mut self) {
+ self.just_released_keys.clear();
+ }
+
+ /// Clears all just pressed keys
+ pub(super) fn clear_just_pressed(&mut self) {
+ self.just_pressed_keys.clear();
}
}
diff --git a/src/input/systems.rs b/src/input/systems.rs
index 9560e1e..9be9f25 100644
--- a/src/input/systems.rs
+++ b/src/input/systems.rs
@@ -29,7 +29,8 @@ pub fn input_handling(
mut input: ResMut<TerminalInput>,
mut event_writer: EventWriter<TerminalInputEvent>,
) {
- input.clear_released();
+ input.clear_just_released();
+ input.clear_just_pressed();
let mut event_queue = event_queue.0.lock().unwrap();
let mut key_events = Vec::<KeyEvent>::new();
while let Some(event) = event_queue.pop() {
@@ -51,4 +52,4 @@ pub fn input_handling(
_ => (),
}
}
-} \ No newline at end of file
+}