Archived
1
0
keybrd library is an open source library for creating custom-keyboard firmware.
This repo is archived. You can view files and clone it, but cannot push or open issues or pull requests.
Go to file
2016-06-01 09:58:03 -06:00
doc rename Row to RowBase, move debounce() to Row_DH 2016-05-31 06:39:08 -06:00
examples add debounce_unit_test.cpp 2016-06-01 08:34:00 -06:00
src rename previousDebounced, debounced 2016-06-01 09:58:03 -06:00
tutorials document 2016-05-29 21:23:33 -06:00
library.properties initial commit keybrd version 0.3.0 2016-05-09 08:05:08 -06:00
LICENSE.txt initial commit keybrd version 0.3.0 2016-05-09 08:05:08 -06:00
README.md document 2016-05-29 21:23:33 -06:00

keybrd library for creating keyboard firmware

keybrd library is an open source library for creating custom-keyboard firmware. The resulting keyboard firmware is compatible with standard USB keyboard drivers.

keybrd library can support any keyboard configuration:

  • one-piece
  • split with I/O expander
  • single-layer
  • multiple-layer

Multiple-layer keyboards can write symbols without using the shift key:

~ ! @ # $ % ^ & * () _ {} | < > : ?

keybrd library leverages the Arduino environment to create keyboard firmware. The Arduino development environment is free, and easy for novice programmers to setup and learn.

The keybrd library has been tested on the Teensy 2.0 microcontroller, MCP23018 I/O expander, and PCA9655E I/O expander.

The public API should not be considered stable. Currently the keybrd library is limited to 8x8 matrices, which is enough for compact split keyboards.

Example minimal keybrd sketch

A minimal keybrd sketch. has about 50 lines of code and runs on a 4-key keyboard. It runs on a breadboard and has rows, columns, and diodes just like the big keyboards. The sketch is small because the keybrd library takes care of the low-level details.

The keybrd tutorial 1 shows how to make a breadboard keyboard. The remaining keybrd tutorials show how to create custom keybrd firmware.

Example complex keybrd sketch

The keybrd_DH emulates the DataHand keyboard. It has 72 keys, 4 layers, 6 sub-layers, 2 matrices, 8 LEDs, and blinking LEDs. The keybrd_DH and its instantiation files contain about 800 lines of code.

mainSketch.ino
instantiations_ports.h
instantiations_LEDs.h
instantiations_codes.h
instantiations_matrix.h

Support

Guides and tutorials are provided. Please ask a questions in issues if something is not clear.