2022-02-20 20:55:22 +01:00
|
|
|
# Kyria Keyboard
|
|
|
|
|
|
|
|
A split keyboard with a 3x6 columnar stagger and 7 thumb keys. One button on each side is usually replaced by an
|
|
|
|
encoder.
|
|
|
|
|
|
|
|
Official retailer of Kyria PCB: [splitkb.com](https://splitkb.com/collections/keyboard-kits/products/kyria-pcb-kit). PCB
|
|
|
|
was designed with QMK in mind and KMK implementation is not officially supported by PCB designer and seller.
|
|
|
|
|
|
|
|
Keyboard works with controllers having Pro Micro layout. Existing configurations:
|
|
|
|
|
2022-10-09 18:08:03 +02:00
|
|
|
| PCB version | Board | Config file |
|
|
|
|
|:-----------:|-------------------------------------|---------------------------|
|
|
|
|
| 1.* | Any quickpin pro micro based board. | kb_v1_ |
|
|
|
|
| 2.* | Any quickpin pro micro based board. | _waiting for pinout docs_ |
|
2022-02-20 20:55:22 +01:00
|
|
|
|
|
|
|
## Compatibility issues
|
|
|
|
|
|
|
|
- **TRRS connection** - KMK has no protocol for one-pin communication between two splits. So, if you are using TRRS wire
|
|
|
|
connection, only right side send matrix events to the left side. No issue when using BLE.
|
|
|
|
- **Right side encoder** - right encoder currently doesn't send updates to left half and can even freeze right half
|
|
|
|
- **OLED screens** - OLED screens are not required, but often element of Kyria keyboards. KMK have no official OLED
|
|
|
|
implementation, but as it's based on Circuit Python, adding one is very simple and there are many examples, also on
|
|
|
|
KMK forks
|
|
|
|
|
|
|
|
## `main.py` example config
|
|
|
|
|
|
|
|
Current layout is based on default [QMK Kyria layout](https://config.qmk.fm/#/splitkb/kyria/rev1/LAYOUT)
|
|
|
|
|
|
|
|
It has the following modules/extensions enabled:
|
|
|
|
|
2022-09-02 03:50:44 +02:00
|
|
|
- [Split](/docs/split_keyboards.md) Connects halves using a wire
|
|
|
|
- [Layers](/docs/layers.md) Do you need more keys than switches? Use
|
2022-02-20 20:55:22 +01:00
|
|
|
layers.
|
2022-09-02 03:50:44 +02:00
|
|
|
- [ModTap](/docs/modtap.md) Enable press/hold double binding of keys
|
|
|
|
- [MediaKeys](/docs/media_keys.md) Common media controls
|
2022-02-20 20:55:22 +01:00
|
|
|
|
|
|
|
Also uncomment right section to enable samples of following:
|
|
|
|
|
2022-09-02 03:50:44 +02:00
|
|
|
- [RGB](/docs/rgb.md) Turn on the backlight (**requires neopixel.py
|
2022-02-20 20:55:22 +01:00
|
|
|
library to work**)
|
2022-09-02 03:50:44 +02:00
|
|
|
- [Encoder](docs/encoder.md) Make the knobs do something
|
2022-02-20 20:55:22 +01:00
|
|
|
|
|
|
|
## More steps required during install
|
|
|
|
|
|
|
|
In order to mitigate lack of one-wire protocol, KMK use its UART implementation but with special low-level PIO
|
|
|
|
subprogram available only on RP2040. It allows using other pins for UART than on-board RX and TX.
|
|
|
|
|
|
|
|
Because of the above, besides of normal installation steps, you have to also:
|
|
|
|
|
|
|
|
- install Circuit Python in 7.2+ version
|
|
|
|
- add `adafruit_pioasm.mpy` library to lib or root folder of a board
|
2022-10-09 18:08:03 +02:00
|
|
|
|
|
|
|
## Microcontroller support
|
|
|
|
|
2022-10-11 01:04:31 +02:00
|
|
|
Update this line in `kb.py` to any supported microcontroller in `kmk/quickpin/pro_micro`:
|
2022-10-09 18:08:03 +02:00
|
|
|
|
|
|
|
```python
|
|
|
|
from kmk.quickpin.pro_micro.boardsource_blok import pinout as pins
|
|
|
|
```
|