pub struct Key<K: Key> {
pub tap: K,
pub hold: K,
}
Expand description
A key with tap-hold functionality.
Fields§
§tap: K
The ‘tap’ key.
hold: K
The ‘hold’ key.
Implementations§
Source§impl<K: Key> Key<K>
impl<K: Key> Key<K>
Sourcepub fn new_pressed_key(
&self,
context: Context,
keymap_index: u16,
) -> (PressedKeyState<K>, ScheduledEvent<Event>)
pub fn new_pressed_key( &self, context: Context, keymap_index: u16, ) -> (PressedKeyState<K>, ScheduledEvent<Event>)
Constructs a new pressed key state and a scheduled event for the tap-hold key.
Trait Implementations§
Source§impl<'de, K> Deserialize<'de> for Key<K>where
K: Deserialize<'de> + Key,
impl<'de, K> Deserialize<'de> for Key<K>where
K: Deserialize<'de> + Key,
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl<K: TapHoldNestable> From<Key<K>> for TapHoldKey<K>
impl<K: TapHoldNestable> From<Key<K>> for TapHoldKey<K>
Source§impl<K: TapHoldNestable> Key for Key<K>
impl<K: TapHoldNestable> Key for Key<K>
Source§type Context = Context
type Context = Context
The associated Context is used to provide state that
may affect behaviour when pressing the key.
(e.g. the behaviour of layered::LayeredKey depends on which
layers are active in layered::Context).
Source§type PressedKey = PressedKey<TapHoldKey<BaseKey>, TapHoldPressedKeyState<BaseKey>>
type PressedKey = PressedKey<TapHoldKey<BaseKey>, TapHoldPressedKeyState<BaseKey>>
The associated PressedKeyState implements functionality
for the pressed key.
(e.g. tap_hold::PressedKeyState implements behaviour resolving
the pressed tap hold key as either ‘tap’ or ‘hold’).
Source§fn new_pressed_key(
&self,
context: Self::Context,
keymap_index: u16,
) -> (Self::PressedKey, PressedKeyEvents<Self::Event>)
fn new_pressed_key( &self, context: Self::Context, keymap_index: u16, ) -> (Self::PressedKey, PressedKeyEvents<Self::Event>)
Key::new_pressed_key produces a pressed key value, and may
yield some ScheduledEvents.
(e.g. tap_hold::Key schedules a tap_hold::Event::TapHoldTimeout
so that holding the key resolves as a hold).
impl<K: Copy + Key> Copy for Key<K>
impl<K: Key> StructuralPartialEq for Key<K>
Auto Trait Implementations§
impl<K> Freeze for Key<K>where
K: Freeze,
impl<K> RefUnwindSafe for Key<K>where
K: RefUnwindSafe,
impl<K> Send for Key<K>where
K: Send,
impl<K> Sync for Key<K>where
K: Sync,
impl<K> Unpin for Key<K>where
K: Unpin,
impl<K> UnwindSafe for Key<K>where
K: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more