mirror of
https://github.com/qmk/qmk_firmware.git
synced 2024-11-25 04:43:02 +00:00
Document chordal_hold_handedness().
This commit is contained in:
parent
8f86425ffc
commit
5b5ff41d79
@ -508,9 +508,9 @@ const char chordal_hold_layout[MATRIX_ROWS][MATRIX_COLS] PROGMEM =
|
|||||||
|
|
||||||
Use the same `LAYOUT` macro as used to define your keymap layers. Each entry is
|
Use the same `LAYOUT` macro as used to define your keymap layers. Each entry is
|
||||||
a character indicating the handedness of one key, either `'L'` for left, `'R'`
|
a character indicating the handedness of one key, either `'L'` for left, `'R'`
|
||||||
for right, or `'*'` to exempt keys from the "opposite hands rule." When a key
|
for right, or `'*'` to exempt keys from the "opposite hands rule." A key with
|
||||||
has `'*'` handedness, pressing it with either hand results in a hold. This could
|
`'*'` handedness may settle as held in chords with any other key. This could be
|
||||||
be used perhaps on thumb keys or other places where you want to allow same-hand
|
used perhaps on thumb keys or other places where you want to allow same-hand
|
||||||
chords.
|
chords.
|
||||||
|
|
||||||
Keyboard makers may specify handedness in keyboard.json. Under `"layouts"`,
|
Keyboard makers may specify handedness in keyboard.json. Under `"layouts"`,
|
||||||
@ -522,6 +522,34 @@ layouts, only the first one is read. For example:
|
|||||||
{"matrix": [5, 6], "x": 0, "y": 5.5, "w": 1.25, "hand", "*"},
|
{"matrix": [5, 6], "x": 0, "y": 5.5, "w": 1.25, "hand", "*"},
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Alternatively, handedness may be defined functionally with
|
||||||
|
`chordal_hold_handedness()`. For example, in keymap.c define:
|
||||||
|
|
||||||
|
```c
|
||||||
|
char chordal_hold_handedness(keypos_t key) {
|
||||||
|
if (key.col == 0 || key.col == MATRIX_COLS - 1) {
|
||||||
|
return '*'; // Exempt the outer columns.
|
||||||
|
}
|
||||||
|
// On split keyboards, typically, the first half of the rows are on the
|
||||||
|
// left, and the other half are on the right.
|
||||||
|
return key.row < MATRIX_ROWS / 2 ? 'L' : 'R';
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Given the matrix position of a key, the function should return `'L'`, `'R'`, or
|
||||||
|
`'*'`. Adapt the logic in this function according to the keyboard's matrix.
|
||||||
|
|
||||||
|
::: warning
|
||||||
|
Note the matrix may have irregularities around larger keys, around the edges of
|
||||||
|
the board, and around thumb clusters. You may find it helpful to use [this
|
||||||
|
debugging example](faq_debug#which-matrix-position-is-this-keypress) to
|
||||||
|
correspond physical keys to matrix positions.
|
||||||
|
:::
|
||||||
|
|
||||||
|
::: tip If you define both `chordal_hold_layout[MATRIX_ROWS][MATRIX_COLS]` and
|
||||||
|
`chordal_hold_handedness(keypos_t key)` for handedness, the latter takes
|
||||||
|
precedence.
|
||||||
|
|
||||||
|
|
||||||
### Per-chord customization
|
### Per-chord customization
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user