prepare holdtap for tapdance refactor
This commit is contained in:
parent
29abba63e7
commit
0751f6ca5f
@ -1,6 +1,8 @@
|
|||||||
from micropython import const
|
from micropython import const
|
||||||
|
|
||||||
|
from kmk.keys import make_argumented_key
|
||||||
from kmk.modules import Module
|
from kmk.modules import Module
|
||||||
|
from kmk.types import HoldTapKeyMeta
|
||||||
|
|
||||||
|
|
||||||
class ActivationType:
|
class ActivationType:
|
||||||
@ -24,6 +26,12 @@ class HoldTap(Module):
|
|||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.key_buffer = []
|
self.key_buffer = []
|
||||||
self.key_states = {}
|
self.key_states = {}
|
||||||
|
make_argumented_key(
|
||||||
|
validator=HoldTapKeyMeta,
|
||||||
|
names=('HT',),
|
||||||
|
on_press=self.ht_pressed,
|
||||||
|
on_release=self.ht_released,
|
||||||
|
)
|
||||||
|
|
||||||
def during_bootup(self, keyboard):
|
def during_bootup(self, keyboard):
|
||||||
return
|
return
|
||||||
@ -58,6 +66,9 @@ class HoldTap(Module):
|
|||||||
|
|
||||||
self.send_key_buffer(keyboard)
|
self.send_key_buffer(keyboard)
|
||||||
|
|
||||||
|
if state.activated == ActivationType.INTERRUPTED:
|
||||||
|
current_key = keyboard._find_key_in_map(int_coord)
|
||||||
|
|
||||||
# if interrupt on release: store interrupting keys until one of them
|
# if interrupt on release: store interrupting keys until one of them
|
||||||
# is released.
|
# is released.
|
||||||
if key.meta.tap_interrupted:
|
if key.meta.tap_interrupted:
|
||||||
@ -140,16 +151,16 @@ class HoldTap(Module):
|
|||||||
self.key_buffer.clear()
|
self.key_buffer.clear()
|
||||||
|
|
||||||
def ht_activate_hold(self, key, keyboard, *args, **kwargs):
|
def ht_activate_hold(self, key, keyboard, *args, **kwargs):
|
||||||
pass
|
keyboard.process_key(key.meta.hold, True)
|
||||||
|
|
||||||
def ht_deactivate_hold(self, key, keyboard, *args, **kwargs):
|
def ht_deactivate_hold(self, key, keyboard, *args, **kwargs):
|
||||||
pass
|
keyboard.process_key(key.meta.hold, False)
|
||||||
|
|
||||||
def ht_activate_tap(self, key, keyboard, *args, **kwargs):
|
def ht_activate_tap(self, key, keyboard, *args, **kwargs):
|
||||||
pass
|
keyboard.process_key(key.meta.tap, True)
|
||||||
|
|
||||||
def ht_deactivate_tap(self, key, keyboard, *args, **kwargs):
|
def ht_deactivate_tap(self, key, keyboard, *args, **kwargs):
|
||||||
pass
|
keyboard.process_key(key.meta.tap, False)
|
||||||
|
|
||||||
def ht_activate_on_interrupt(self, key, keyboard, *args, **kwargs):
|
def ht_activate_on_interrupt(self, key, keyboard, *args, **kwargs):
|
||||||
if key.meta.prefer_hold:
|
if key.meta.prefer_hold:
|
||||||
|
12
kmk/types.py
12
kmk/types.py
@ -12,8 +12,16 @@ class AttrDict(dict):
|
|||||||
|
|
||||||
|
|
||||||
class HoldTapKeyMeta:
|
class HoldTapKeyMeta:
|
||||||
def __init__(self, kc=None, prefer_hold=True, tap_interrupted=False, tap_time=None):
|
def __init__(
|
||||||
self.kc = kc
|
self,
|
||||||
|
tap,
|
||||||
|
hold,
|
||||||
|
prefer_hold=True,
|
||||||
|
tap_interrupted=False,
|
||||||
|
tap_time=None,
|
||||||
|
):
|
||||||
|
self.tap = tap
|
||||||
|
self.hold = hold
|
||||||
self.prefer_hold = prefer_hold
|
self.prefer_hold = prefer_hold
|
||||||
self.tap_interrupted = tap_interrupted
|
self.tap_interrupted = tap_interrupted
|
||||||
self.tap_time = tap_time
|
self.tap_time = tap_time
|
||||||
|
Loading…
x
Reference in New Issue
Block a user