Skip to content

Commit

Permalink
Add example for AutoShift explicit config
Browse files Browse the repository at this point in the history
Add an example ino-file and add a paragraph to the README about the
usage.

Signed-off-by: Marco Herrn <[email protected]>
  • Loading branch information
hupfdule committed Apr 14, 2023
1 parent 38b36dc commit c3976cb
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 0 deletions.
4 changes: 4 additions & 0 deletions examples/Keystrokes/AutoShift/AutoShift.ino
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,10 @@ void setup() {
AutoShift.setEnabled(AutoShift.letterKeys() | AutoShift.numberKeys());
// Add symbol keys to the enabled categories:
AutoShift.enable(AutoShift.symbolKeys());
// instead of shifting, produce a backslash on long pressing slash
AUTOSHIFT(
kaleidoscope::plugin::LongPress(Key_Slash, Key_Backslash),
)
// Set the AutoShift long-press time to 150ms:
AutoShift.setTimeout(150);
// Start with AutoShift turned off:
Expand Down
24 changes: 24 additions & 0 deletions plugins/Kaleidoscope-AutoShift/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,30 @@ As you can see, this method takes a `Key` as its input and returns either `true`
(for keys eligible to be auto-shifted) or `false` (for keys AutoShift will leave
alone).

## Producing other characters than shifted variants of the keys

It is possible to produce other characters than just shifted variants of the
pressed key by providing an explicit mapping between the pressed key and the
key that should be produced instead.

Such a mapping must be defined in the `setup` method in your sketch:

```
AUTOSHIFT(
kaleidoscope::plugin::LongPress(Key_Slash, Key_Backslash),
kaleidoscope::plugin::LongPress(Key_Z, ShiftToLayer(SYMBOL)),
)
```

Such explicit mappings take precedence over shifting the key. That
means if all alphanumeric characters are configured for AutoShift, but
the ‘e’ key has an explicit mapping to produce ‘ë’, a long press on ‘e’
will result in ’ë’, not ‘E’.

As can be seen in the example above the resulting key does not necessarily need
to be a regular key, but can be any Key object, like the layer shift in the
example. Be aware however that key repeats are not suppressed.

## Plugin compatibility

If you're using AutoShift in a sketch that also includes the Qukeys and/or
Expand Down

0 comments on commit c3976cb

Please sign in to comment.