2020-10-21 21:19:42 +02:00
|
|
|
# ModTap Keycodes
|
|
|
|
Enabling ModTap will give you access to the following keycodes and can simply be
|
|
|
|
added to the modules list.
|
|
|
|
|
|
|
|
```python
|
|
|
|
from kmk.modules.modtap import ModTap
|
2022-01-18 06:21:05 +01:00
|
|
|
modtap = ModTap()
|
|
|
|
# optional: set a custom tap timeout in ms
|
|
|
|
# modtap.tap_time = 300
|
|
|
|
keyboard.modules.append(modtap)
|
2020-10-21 21:19:42 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
## Keycodes
|
2019-03-04 01:28:13 +01:00
|
|
|
|
2022-04-24 20:46:49 +02:00
|
|
|
|New Keycode | Description |
|
|
|
|
|---------------------------------------------------------|-----------------------------------------------------------------|
|
|
|
|
|`LCTL = KC.MT(KC.SOMETHING, KC.LCTRL)` |`LCTRL` if held `kc` if tapped |
|
|
|
|
|`LSFT = KC.MT(KC.SOMETHING, KC.LSFT)` |`LSHIFT` if held `kc` if tapped |
|
|
|
|
|`LALT = KC.MT(KC.SOMETHING, KC.LALT)` |`LALT` if held `kc` if tapped |
|
|
|
|
|`LGUI = KC.MT(KC.SOMETHING, KC.LGUI)` |`LGUI` if held `kc` if tapped |
|
|
|
|
|`RCTL = KC.MT(KC.SOMETHING, KC.RCTRL)` |`RCTRL` if held `kc` if tapped |
|
|
|
|
|`RSFT = KC.MT(KC.SOMETHING, KC.RSFT)` |`RSHIFT` if held `kc` if tapped |
|
|
|
|
|`RALT = KC.MT(KC.SOMETHING, KC.RALT)` |`RALT` if held `kc` if tapped |
|
|
|
|
|`RGUI = KC.MT(KC.SOMETHING, KC.RGUI)` |`RGUI` if held `kc` if tapped |
|
|
|
|
|`SGUI = KC.MT(KC.SOMETHING, KC.LSHFT(KC.LGUI))` |`LSHIFT` and `LGUI` if held `kc` if tapped |
|
|
|
|
|`LCA = KC.MT(KC.SOMETHING, KC.LCTRL(KC.LALT))` |`LCTRL` and `LALT` if held `kc` if tapped |
|
|
|
|
|`LCAG = KC.MT(KC.SOMETHING, KC.LCTRL(KC.LALT(KC.LGUI)))` |`LCTRL` and `LALT` and `LGUI` if held `kc` if tapped |
|
|
|
|
|`MEH = KC.MT(KC.SOMETHING, KC.LCTRL(KC.LSFT(KC.LALT)))` |`CTRL` and `LSHIFT` and `LALT` if held `kc` if tapped |
|
|
|
|
|`HYPR = KC.MT(KC.SOMETHING, KC.HYPR)` |`LCTRL` and `LSHIFT` and `LALT` and `LGUI` if held `kc` if tapped|
|
2019-03-05 00:28:45 +01:00
|
|
|
|
2022-02-07 19:39:31 +01:00
|
|
|
## Custom HoldTap Behavior
|
|
|
|
The full ModTap signature is as follows:
|
|
|
|
```python
|
2022-10-02 18:41:33 +02:00
|
|
|
KC.MT(KC.TAP, KC.HOLD, prefer_hold=True, tap_interrupted=False, tap_time=None, repeat=False)
|
2022-02-07 19:39:31 +01:00
|
|
|
```
|
|
|
|
* `prefer_hold`: decides which keycode the ModTap key resolves to when another
|
|
|
|
key is pressed before the timeout finishes. When `True` the hold keycode is
|
2022-04-24 19:30:10 +02:00
|
|
|
chosen, the tap keycode when `False`.
|
2022-02-07 19:39:31 +01:00
|
|
|
* `tap_interrupted`: decides if the timeout will interrupt at the first other
|
|
|
|
key press/down, or after the first other key up/release. Set to `True` for
|
|
|
|
interrupt on release.
|
|
|
|
* `tap_time`: length of the tap timeout in milliseconds.
|
2022-10-02 18:41:33 +02:00
|
|
|
* `repeat`: decides how to interpret repeated presses if they happen within
|
|
|
|
`tap_time` after a release.
|
|
|
|
When `True` the repeated press sends the previous keycode, no matter
|
|
|
|
how long the key remains pressed the second time.
|
|
|
|
This allows to hold the tap keycode, or repeatedly tap the hold keycode.
|
|
|
|
When `False` repeated presses are independent.
|
2019-03-04 01:28:13 +01:00
|
|
|
|
2022-02-07 19:39:31 +01:00
|
|
|
Each of these parameters can be set for every ModTap key individually.
|