Skip to content

Keyball

Keyball is a family of keyboards that feature a 34mm thumb trackball with the widely used PMW3360 sensor. In partnership with Yowkees of Shirogane Lab, the creator of this wonderful integrated trackball design, we're happy to bring Keyball to a wider audience.

The trackball sits in an injected molded housing with 3 ceramic bearings. The ball slides snuggly into the housing and moves smoothly in all directions thanks to the bearings.

keyball39

Buyer's Guide

Most of the general purpose Buyer's Guide applies to Keyball lineup of keyboards as well, it stands out in a few ways described below.

First, it's worth noting that our Keyball differ from the one sold by Yushakobo / Shirogane Lab. In terms of cosmetics, we use black PCBs, different thickness acrylic plates and different M2 screws. Additionally, we use Sea-Picro. The rest is identical.

34mm Trackball

Keyball uses a 34mm trackball that's not included in your purchase. There are many color options to choose from, and the ones made by Perixx are a popular choice.

Thumb Cluster

Keyball has a unique thumb cluster that allows either Kailh's choc low profile or MX switches. Whether you're buying a kit or a prebuilt one, you will get choc hotswap sockets. This option lets you also add choc switches and keycaps to your order.

Build Guide

keyball kit

Please refer to the canonical Keyball guide below:

Come back to this page when you're at the firmware step, as it differs from the guide above.

For build help that's not specific to Keyball, you're welcome to visit the Keyboard guide in these docs.

Firmware

Keyball's firmware is maintained in a dedicated repository by the designer of the keyboard and is written for Pro Micro controllers. A port of the firmware for RP2040 controllers is available in this holykeebs repository.

DANGER

Avoid connecting / disconnecting the TRRS cable when the keyboard is powered. This can short the GPIO pins of the controllers.

If you'd like to compile your own firmware, see the Firmware page on setting up the environment.

Once you have your own clone, while on the holykeebs-master branch, flash both sides using (adjust the name to the Keyball you have):

shell
make keyball/keyball44:via:flash -j8

USB cable can be connected to either side of the keyboard. If your trackball doesn't work, try switching the cable to the side with the trackball.

Custom Keycodes

Keyball comes with custom keycodes that provide access to Keyball features without needing to compile your own firmware. These features are accessible through the following Special Keycodes that can be assigned when using Remap:

KeycodeValue on RemapHexDescription
KBC_RSTKb 00x7e00Reset Keyball configuration
KBC_SAVEKb 10x7e01Save Keyball configuration to memory (EEPROM)
CPI_I100Kb 20x7e02Increase pointer speed by 100 CPI (max 12000)
CPI_D100Kb 30x7e03Decrease pointer speed by 100 CPI (min 100)
CPI_I1KKb 40x7e04Increase pointer speed by 1000 CPI (max 12000)
CPI_D1KKb 50x7e05Decrease pointer speed by 1000 CPI (min 100)
SCRL_TOKb 60x7e06Toggle scroll mode
SCRL_MOKb 70x7e07Enable scroll mode (while held)
SCRL_DVIKb 80x7e08Decrease scroll speed (max D7 = 1/128)
SCRL_DVDKb 90x7e09Increase scroll speed (min D0 = 1/1)
AML_TOKb 100x7e0aToggle automatic mouse layer
AML_I50Kb 110x7e0bIncrease automatic mouse layer timeout by 50ms (max 1000ms)
AML_D50Kb 120x7e0cDecrease automatic mouse layer timeout by 50ms (min 100ms)
SSNP_VRTKb 130x7e0dLock scroll direction to vertical only
SSNP_HORKb 140x7e0eLock scroll direction to horizontal only
SSNP_FREKb 150x7e0fDisable scroll direction lock (free scroll)

If you wish to have your current configuration persist across reboots, use the KBC_SAVE keycode to save it to memory. Please note that each half of the Keyball has separate memory, so if you wish to have same behavior regardless of which half is plugged in, you will need to repeat the configuration for each half.

Building Your Own Firmware

Please see the Firmware guide.