1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
use hashbrown::{HashMap, HashSet};
use notan_core::events::Event;
pub use notan_core::keyboard::KeyCode;
#[derive(Default)]
pub struct Keyboard {
pub pressed: HashSet<KeyCode>,
pub down: HashMap<KeyCode, f32>,
pub released: HashSet<KeyCode>,
pub last_key_released: Option<KeyCode>,
}
impl Keyboard {
pub fn last_key_released(&self) -> Option<KeyCode> {
self.last_key_released
}
pub fn was_released(&self, key: KeyCode) -> bool {
self.released.contains(&key)
}
pub fn is_down(&self, key: KeyCode) -> bool {
self.down.contains_key(&key)
}
pub fn down_delta(&self, key: KeyCode) -> f32 {
*self.down.get(&key).unwrap_or(&0.0)
}
pub fn was_pressed(&self, key: KeyCode) -> bool {
self.pressed.contains(&key)
}
#[inline]
pub fn ctrl(&self) -> bool {
self.is_down(KeyCode::RControl) || self.is_down(KeyCode::LControl)
}
#[inline]
pub fn alt(&self) -> bool {
self.is_down(KeyCode::RAlt) || self.is_down(KeyCode::LAlt)
}
#[inline]
pub fn shift(&self) -> bool {
self.is_down(KeyCode::RShift) || self.is_down(KeyCode::LShift)
}
#[inline]
pub fn logo(&self) -> bool {
self.is_down(KeyCode::RWin) || self.is_down(KeyCode::LWin)
}
pub(crate) fn clear(&mut self) {
self.pressed.clear();
self.released.clear();
}
#[inline]
pub(crate) fn process_events(&mut self, evt: &Event, delta: f32) {
match evt {
Event::KeyUp { key } => {
self.down.remove(key);
self.pressed.remove(key);
self.released.insert(*key);
self.last_key_released = Some(*key);
}
Event::KeyDown { key } => {
if let Some(t) = self.down.get_mut(key) {
*t += delta;
} else {
self.down.insert(*key, 0.0);
self.pressed.insert(*key);
}
}
_ => {}
}
}
}