2019-07-25 07:27:16 +02:00
|
|
|
# Configuring KMK
|
|
|
|
|
|
|
|
KMK is configured through a rather large plain-old-Python class called
|
2019-07-25 10:30:55 +02:00
|
|
|
`KMKKeyboard`. Subclasses of this configuration exist which pre-fill defaults
|
2022-04-29 20:21:16 +02:00
|
|
|
for various known keyboards (for example, many QMK, TMK, or ZMK keyboards
|
2022-06-22 11:25:57 +02:00
|
|
|
are supported with a nice!nano, or through our ItsyBitsy to Pro Micro pinout adapter.)
|
2022-04-29 20:21:16 +02:00
|
|
|
This class is the main interface between end users and the inner workings of KMK.
|
2020-10-21 21:19:42 +02:00
|
|
|
Let's dive in!
|
2019-07-25 07:27:16 +02:00
|
|
|
|
|
|
|
- Edit or create a file called `main.py` on your `CIRCUITPY` drive. You can also
|
|
|
|
keep this file on your computer (perhaps under `user_keymaps` - please feel
|
|
|
|
free to submit a pull request with your layout definitions!) and copy it over
|
|
|
|
(either manually or, if you're adept with developer tooling and/or a command
|
|
|
|
line, [our
|
|
|
|
Makefile](https://github.com/KMKfw/kmk_firmware/blob/master/docs/flashing.md)).
|
|
|
|
It's definitely recommended to keep a backup of your configuration somewhere
|
|
|
|
that isn't the microcontroller itself - MCUs die, CircuitPython may run into
|
|
|
|
corruption bugs, or you might just have bad luck and delete the wrong file
|
|
|
|
some day.
|
|
|
|
|
2019-07-25 10:30:55 +02:00
|
|
|
- Assign a `KMKKeyboard` instance to a variable (ex. `keyboard = KMKKeyboard()` - note
|
2019-07-25 07:27:16 +02:00
|
|
|
the parentheses)
|
|
|
|
|
2019-07-25 10:30:55 +02:00
|
|
|
- Make sure this `KMKKeyboard` instance is actually run at the end of the file with
|
2019-07-25 07:27:16 +02:00
|
|
|
a block such as the following:
|
|
|
|
|
|
|
|
```python
|
|
|
|
if __name__ == '__main__':
|
|
|
|
keyboard.go()
|
|
|
|
```
|
|
|
|
|
|
|
|
- Assign pins and your diode orientation (only necessary on handwire keyboards),
|
|
|
|
for example:
|
|
|
|
|
|
|
|
```python
|
2019-07-25 10:20:14 +02:00
|
|
|
import board
|
|
|
|
|
2022-04-09 02:09:24 +02:00
|
|
|
from kmk.scanners import DiodeOrientation
|
Continue to shuffle and burn stuff
- Remove the concept of "mcus". With only one target platform
(CircuitPython), it no longer makes a bunch of sense and has been kept
around for "what if" reasons, complicating our import chains and eating
up RAM for pointless subclasses. If you're a `board`, you derive from
`KeyboardConfig`. If you're a handwire, the user will derive from
`KeyboardConfig`. The end. As part of this, `kmk.hid` was refactored
heavily to emphasize that CircuitPython is our only supported HID stack,
with stubs for future HID implementations (`USB_HID` becomes
`AbstractHID`, probably only usable for testing purposes,
`CircuitPython_USB_HID` becomes `USBHID`, and `BLEHID` is added with an
immediate `NotImplementedError` on instantiation)
- `KeyboardConfig` can now take a HID type at runtime. The NRF52840
boards will happily run in either configuration once CircuitPython
support is in place, and a completely separate `mcu` subclass for each
mode made no sense. This also potentially allows runtime *swaps* of HID
driver down the line, but no code has been added to this effect. The
default, and only functional value, for this is `HIDModes.USB`
- Most consts have been moved to more logical homes - often, the main
or, often only, component that uses them. `DiodeOrientation` moved to
`kmk.matrix`, and anything HID-related moved to `kmk.hid`
2019-07-25 09:58:23 +02:00
|
|
|
|
2019-07-25 10:20:14 +02:00
|
|
|
col_pins = (board.SCK, board.MOSI, board.MISO, board.RX, board.TX, board.D4)
|
|
|
|
row_pins = (board.D10, board.D11, board.D12, board.D13, board.D9, board.D6, board.D5, board.SCL)
|
2019-07-25 07:27:16 +02:00
|
|
|
rollover_cols_every_rows = 4
|
2021-09-14 05:30:05 +02:00
|
|
|
diode_orientation = DiodeOrientation.COL2ROW
|
2019-07-25 07:27:16 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
The pins should be based on whatever CircuitPython calls pins on your particular
|
|
|
|
board. You can find these in the REPL on your CircuitPython device:
|
|
|
|
|
|
|
|
```python
|
|
|
|
import board
|
|
|
|
print(dir(board))
|
|
|
|
```
|
|
|
|
|
|
|
|
> Note: `rollover_cols_every_rows` is only supported with
|
2021-09-14 05:30:05 +02:00
|
|
|
> `DiodeOrientation.COLUMNS`/`DiodeOrientation.COL2ROW`, not `DiodeOrientation.ROWS`/`DiodeOrientation.ROW2COL`. It is used for boards
|
2019-07-25 07:27:16 +02:00
|
|
|
> such as the Planck Rev6 which reuse column pins to simulate a 4x12 matrix in
|
|
|
|
> the form of an 8x6 matrix
|
|
|
|
|
|
|
|
- Import the global list of key definitions with `from kmk.keys import KC`. You
|
|
|
|
can either print this out in the REPL as we did with `board` above, or simply
|
|
|
|
look at [our Key
|
|
|
|
documentation](https://github.com/KMKfw/kmk_firmware/blob/master/docs/keycodes.md).
|
|
|
|
We've tried to keep that listing reasonably up to date, but if it feels like
|
|
|
|
something is missing, you may need to read through `kmk/keys.py` (and then
|
|
|
|
open a ticket to tell us our docs are out of date, or open a PR and fix the
|
|
|
|
docs yourself!)
|
|
|
|
|
|
|
|
- Define a keymap, which is, in Python terms, a List of Lists of `Key` objects.
|
|
|
|
A very simple keymap, for a keyboard with just two physical keys on a single
|
|
|
|
layer, may look like this:
|
|
|
|
|
|
|
|
```python
|
|
|
|
keyboard.keymap = [[KC.A, KC.B]]
|
|
|
|
```
|
|
|
|
|
|
|
|
You can further define a bunch of other stuff:
|
|
|
|
|
2020-10-21 21:19:42 +02:00
|
|
|
- `keyboard.debug_enabled` which will spew a ton of debugging information to the serial
|
2019-07-25 07:27:16 +02:00
|
|
|
console. This is very rarely needed, but can provide very valuable information
|
|
|
|
if you need to open an issue.
|
|
|
|
|
2020-10-21 21:19:42 +02:00
|
|
|
- `keyboard.tap_time` which defines how long `KC.TT` and `KC.LT` will wait before
|
|
|
|
considering a key "held" (see `layers.md`)
|
2019-07-25 07:27:16 +02:00
|
|
|
|