91032e123f
Very common question, very simple answer. Comments and suggestions welcome
94 lines
3.4 KiB
Markdown
94 lines
3.4 KiB
Markdown
# Layers
|
|
Layers module adds keys for accessing other layers. It can simply be added to
|
|
the extensions list.
|
|
|
|
```python
|
|
from kmk.modules.layers import Layers
|
|
keyboard.modules.append(Layers())
|
|
```
|
|
|
|
## Keycodes
|
|
|
|
|Key |Description |
|
|
|-----------------|--------------------------------------------------------------------------|
|
|
|`KC.DF(layer)` |Switches the default layer until the next time the keyboard powers off |
|
|
|`KC.MO(layer)` |Momentarily activates layer, switches off when you let go |
|
|
|`KC.LM(layer, mod)` |As `MO(layer)` but with `mod` active |
|
|
|`KC.LT(layer, kc)` |Momentarily activates layer if held, sends kc if tapped |
|
|
|`KC.TG(layer)` |Toggles the layer (enables it if no active, and vise versa) |
|
|
|`KC.TO(layer)` |Activates layer and deactivates all other layers |
|
|
|`KC.TT(layer)` |Momentarily activates layer if held, toggles it if tapped repeatedly |
|
|
|
|
## Custom HoldTap Behavior
|
|
`KC.TT` and `KC.LT` use the same heuristic to determine taps and holds as
|
|
ModTap. Check out the [ModTap doc](modtap.md) to find out more.
|
|
|
|
## Working with Layers
|
|
When starting out, care should be taken when working with layers, since it's possible to lock
|
|
yourself to a layer with no way of returning to the base layer short of unplugging your
|
|
keyboard. This is especially easy to do when using the `KC.TO()` keycode, which deactivates
|
|
all other layers in the stack.
|
|
|
|
Some helpful guidelines to keep in mind as you design your layers:
|
|
- Only reference higher-numbered layers from a given layer
|
|
- Leave keys as `KC.TRNS` in higher layers when they would overlap with a layer-switch
|
|
|
|
### Using Multiple Base Layers
|
|
In some cases, you may want to have more than one base layer (for instance you want to use
|
|
both QWERTY and Dvorak layouts, or you have a custom gamepad that can switch between
|
|
different games). In this case, best practice is to have these layers be the lowest, i.e.
|
|
defined first in your keymap. These layers are mutually-exclusive, so treat changing default
|
|
layers with `KC.DF()` the same way that you would treat using `KC.TO()`
|
|
|
|
## Example Code
|
|
For our example, let's take a simple 3x3 macropad with two layers as follows:
|
|
|
|
```python
|
|
from kmk.modules.layers import Layers
|
|
keyboard.modules.append(Layers())
|
|
|
|
# Layer Keys
|
|
MOMENTARY = KC.MO(1)
|
|
MOD_LAYER = KC.LM(1, KC.RCTL)
|
|
LAYER_TAP = KC.LT(1, KC.END, prefer_hold=True, tap_interrupted=False, tap_time=250) # any tap longer than 250ms will be interpreted as a hold
|
|
|
|
keyboard.keymap = [
|
|
# Base layer
|
|
[
|
|
KC.NO, KC.UP, KC.NO,
|
|
KC.LEFT,KC.DOWN,KC.RGHT,
|
|
MOMENTARY, LAYER_TAP, MOD_LAYER,
|
|
],
|
|
|
|
# Function Layer
|
|
[
|
|
KC.F1, KC.F2, KC.F3,
|
|
KC.F4, KC.F5, KC.F6,
|
|
KC.TRNS,KC.TRNS,KC.TRNS,
|
|
],
|
|
]
|
|
```
|
|
|
|
## Advanced Example
|
|
A common question is: "How do I change RGB background based on my active layer?"
|
|
Here is _one_ (simple) way of many to go about it.
|
|
|
|
```python
|
|
from kmk.modules.layers import Layers as _Layers
|
|
from kmk.extensions.rgb import RGB
|
|
|
|
rgb = RGB(...) # your RGB configuration goes here
|
|
keyboard.extensions.append(rgb)
|
|
|
|
class Layers(_Layers):
|
|
last_top_layer = 0
|
|
hues = (4, 20, 69)
|
|
|
|
def after_hid_send(keyboard):
|
|
if keyboard.active_layers[0] != self.last_top_layer:
|
|
self.last_top_layer = keyboard.active_layers[0]
|
|
rgb.set_hsv_fill(self.hues[self.last_top_layer], 255, 255)
|
|
|
|
keyboard.modules.append(Layers())
|
|
```
|