-
Notifications
You must be signed in to change notification settings - Fork 263
Core Plugins
This is a list of the stable core plugins.
Kaleidoscope-DualUse Documentation
There are a number of keys on our keyboards that we usually hold in combination with others. We also have keys that we usually press and release, and don't want to hold them for repeating. Then we have the others which we sometimes hold to repeat them, such as Space held to insert a number of whitespace characters. The interesting thing that falls out of this, is that there are keys we hold, but never tap, and others which we never hold. What if we could combine these?
What if we had a key that acted as Control when held, but Esc when tapped in isolation? No useful functionality lost, and we have one key less to place on the keyboard! We can even put Esc to a more convenient position, perhaps.
Dual-use keys do just this: if you hold them, and press any other key, they will act as a modifier or momentary layer switcher. If you hold them for a longer period, they - again - will act as modifiers / momentary switchers. But if you tap and release them in isolation, they will act as another key instead.
While keyboards usually ship with a keymap programmed in, to be able to change that keymap, without flashing new firmware, we need a way to place the keymap into a place we can update at run-time, and which persists across reboots. Fortunately, we have a bit of EEPROM on the keyboard, and can use it to store either the full keymap (and saving space in the firmware then), or store an overlay there. In the latter case, whenever there is a non-transparent key on the overlay, we will use that instead of the keyboard default.
In short, this plugin allows us to change our keymaps, without having to compile and flash new firmware. It does so through the use of the Focus plugin.
Turn the Esc key into a special key, that can cancel any active OneShot effect - or act as the normal Esc key if none are active. For those times when one accidentally presses a one-shot key, or change their minds.
The KeyLogger plugin, as the name suggests, implements a key logger for the Kaleidoscope firmware. It logs the row and column of every key press and release, along with the event, and the layer number, in a format that is reasonably easy to parse, to the Serial interface.
A word of warning: Having a key logger is as dangerous as it sounds. Anyone who can read the serial events from the keyboard, will know exactly what keys you press, and when. Unless you know what you are doing, and can secure your keyboard, do not enable this plugin.
Leader keys are a kind of key where when they are tapped, all following keys are swallowed, until the plugin finds a matching sequence in the dictionary, it times out, or fails to find any possibilities. When a sequence is found, the corresponding action is executed, but the processing still continues. If any key is pressed that is not the continuation of the existing sequence, processing aborts, and the key is handled normally.
This behaviour is best described with an example. Suppose we want a behaviour where LEAD u
starts unicode input mode, and LEAD u h e a r t
should result in a heart symbol being input, and we want LEAD u 0 0 e 9 SPC
to input é, and any other hex code that follows LEAD u
, should be handled as-is, and passed to the host. Obviously, we can't have all of this in a dictionary.
So we put LEAD u
and LEAD u h e a r t
in the dictionary only. The first will start unicode input mode, the second will type in the magic sequence that results in the symbol, and then aborts the leader sequence processing. With this setup, if we type LEAD u 0
, then LEAD u
will be handled first, and start unicode input mode. Then, at the 0, the plugin notices it is not part of any sequence, so aborts leader processing, and passes the key on as-is, and it ends up being sent to the host. Thus, we covered all the cases of our scenario!
Macros are a standard feature on many keyboards and Kaleidoscope-powered ones are no exceptions. Macros are a way to have a single key-press do a whole lot of things under the hood: conventionally, macros play back a key sequence, but with Kaleidoscope, there is much more we can do. Nevertheless, playing back a sequence of events is still the primary use of macros.
Playing back a sequence means that when we press a macro key, we can have it play pretty much any sequence. It can type some text for us, or invoke a complicated shortcut - the possibilities are endless!
The MagicCombo extension provides a way to perform custom actions when a particular set of keys are held down together. The functionality assigned to these keys are not changed, and the custom action triggers as long as all keys within the set are pressed. The order in which they were pressed do not matter.
This can be used to tie complex actions to key chords.
One-shots are a new kind of behaviour for your standard modifier and momentary layer keys: instead of having to hold them while pressing other keys, they can be tapped and released, and will remain active until any other key is pressed. In short, they turn Shift, A
into Shift+A
, and Fn, 1
to Fn+1
. The main advantage is that this allows us to place the modifiers and layer keys to positions that would otherwise be awkward when chording. Nevertheless, they still act as normal when held, that behaviour is not lost.
Furthermore, if a one-shot key is tapped two times in quick succession, it becomes sticky, and remains active until disabled with a third tap. This can be useful when one needs to input a number of keys with the modifier or layer active, and still does not wish to hold the key down. If this feature is undesirable, unset the OneShot.double_tap_sticky property
(see later).
To make multi-modifier, or multi-layer shortcuts possible, one-shot keys remain active if another one-shot of the same type is tapped, so Ctrl, Alt, b
becomes Ctrl+Alt+b
, and L1, L2, c
is turned into L1+L2+c
.
ShapeShifter is a plugin that makes it considerably easier to change what symbol is input when a key is pressed together with Shift
. If one wants to rearrange the symbols on the number row for example, without modifying the layout on the operating system side, this plugin is where one can turn to.
What it does, is very simple: if any key in its dictionary is found pressed while Shift
is held, it will press another key instead of the one triggering the event. For example, if it sees Shift + 1
pressed together, which normally results in a !
, it will press 4
instead of 1
, inputting $
.
Space Cadet is a way to make it more convenient to input parens - those (
and )
things -, symbols that a lot of programming languages use frequently. If you are working with Lisp, you are using these all the time.
What it does, is that it turns your left and right Shift
keys into parens if you tap and release them, without pressing any other key while holding them. Therefore, to input, say, (print foo)
, you don't need to press Shift
, hold it, and press 9
to get a (
, you simply press and release Shift
, and continue writing. You use it as if you had a dedicated key for parens!
But if you wish to write capital letters, you hold it, as usual, and you will not see any parens when you release it. You can also hold it for a longer time, and it still would act as a Shift
, without the parens inserted on release: this is useful when you want to augment some mouse action with Shift
, to select text, for example.
After getting used to the Space Cadet style of typing, you may wish to enable this sort of functionality on other keys, as well. Fortunately, the Space Cadet plugin is configurable and extensible to support adding symbols to other keys. Along with (
on your left Shift
key and )
on your right Shift
key, you may wish to add other such programming mainstays as {
to your left-side cmd
key, }
to your right-side alt
key, [ to your left Control
key, and ]
to your right Control
key. You can map the keys in whatever way you may wish to do, so feel free to experiment with different combinations and discover what works best for you!
Tap-dance keys are general purpose, multi-use keys, which trigger a different action based on the number of times they were tapped in sequence. As an example to make this clearer, one can have a key that inputs A
when tapped once, inputs B
when tapped twice, and lights up the keyboard in Christmas colors when tapped a third time.
This behaviour is most useful in cases where we have a number of things we perform rarely, where tapping a single key repeatedly is not counter-productive. Such cases include - for example - multimedia forward / backward keys: forward on single tap, backward on double. Of course, one could use modifiers to achieve a similar effect, but that's two keys to use, this is only one. We can also hide some destructive functionality behind a number of taps: reset the keyboard after 4 taps, and light up LEDs in increasingly frightful colors until then.
How does it work?
To not interfere with normal typing, tap-dance keys have two ways to decide when to call an action: they either get interrupted, or they time out. Every time a tap-dance key is pressed, the timer resets, so one does not have to finish the whole tapping sequence within a short time limit. The tap-dance counter continues incrementing until one of these cases happen.
When a tap-dance key is pressed and released, and nothing is pressed on the keyboard until the timeout is reached, then the key will time out, and trigger an action. Which action, depends on the number of times it has been tapped up until this point.
When a tap-dance key is pressed and released, and another key is hit before the timer expires, then the tap-dance key will trigger an action first, perform it, and only then will the firmware continue handling the interrupting key press. This is to preserve the order of keys pressed.
In both of these cases, the tapDanceAction
will be called, with tapDanceIndex
set to the index of the tap-dance action (as set in the keymap), the tapCount
, and tapDanceAction set to either kaleidoscope::TapDance::Interrupt
, or kaleidoscope::TapDance::Timeout
. If we continue holding the key, then as long as it is held, the same function will be called with tapDanceAction set to kaleidoscope::TapDance::Hold
. When the key is released, after either an Interrupt or Timeout action was triggered, the function will be called with tapDanceAction set to kaleidoscope::TapDance::Release
.
These actions allow us to create sophisticated tap-dance setups, where one can tap a key twice and hold it, and have it repeat, for example.
There is one additional value the tapDanceAction parameter can take: kaleidoscope::TapDance::Tap
. It is called with this argument for each and every tap, even if no action is to be triggered yet. This is so that we can have a way to do some side-effects, like light up LEDs to show progress, and so on.
TopsyTurvy is a plugin that inverts the behaviour of the Shift key for some selected keys. That is, if configured so, it will input !
when pressing the 1
key without Shift
, but with the modifier pressed, it will input the original 1
symbol.
Troubleshooting
Advanced Topics
Development and customization
Keyboardio Model 01 docs
- Keyboardio Model 01 Introduction
- Flashing a new bootloader
- Default Model 01 QWERTY Layout
- Common Alternate Layouts
- Hardware Test Mode
Community