Custom keyboard layout/firmware (ErgoDox)

Posted March 22, 2025

Table of Contents

View on Github ▸

Overview

This custom keyboard layout is designed to reduce strain on the hands—especially the pinkies—while improving typing speed and efficiency, particularly for developers. The layout utilizes custom firmware running on QMK and features multiple layers tailored for different tasks, including standard typing, numeric input, symbols, and coding.

Photograph of keyboard and trackball on desk.

Photograph of keyboard and trackball on desk.

Diagram conventions

In the diagrams below, there are a few conventions in use. The main text on a key (centered) represents what is typed or the command when the key is PRESSED. Smaller text on the front of keys in a salmon color represent what is typed or the command when the key is HELD.

In the diagrams of layers other than BASE, keys that are unimportant to that layer are rendered flat and lighter in color. Salmon-colored flat keys represent the key being held down to access the layer. For keys that type alpha characters on the BASE layer that are flat on another layer, the keys do nothing. Keys in the thumb clusters and non-alpha characters perform the same function as on the BASE layer.

Goals

Layers

The keyboard features 5 main layers:

BASE Layer

BASE layer on keyboard.

BASE layer on keyboard.

Modifiers

All modifiers (Control, Shift, Option, Command) function as one-shot keys, meaning they activate on tap and wait for the next keypress before performing the related action.

Special keys

Parentheses () key

New tab / minimize window key

Apostrophe

Combos / Chords

Certain key combinations trigger specific actions:

Leader key – launching apps

The leader key functions similarly to Vim’s leader key, providing fast application launching:

  1. Pressing the leader key starts leader mode
  2. Typing specific key sequences triggers predefined actions via Keyboard Maestro using HYPER1 key combinations
  3. If an unmapped sequence is typed, the system defaults to opening Spotlight Search and entering the typed characters

Example mappings

Timing

The system waits indefinitely for input unless the leader key is tapped again (which brings up an empty Spotlight Search). If a letter is typed after the leader key, the system waits five seconds for further input before executing the command, or commands can be executed immediately by pressing Return.

META keys – in-app commands

The META keys provides quick access to application-specific commands:

NUM Layer

Special keys

NUM layer on keyboard.

NUM layer on keyboard.

SYM Layer

This layer is optimized for quick symbol entry without extra key presses. Lesser-used and advanced symbols (such as those accessible while holding Option) are accessible via key holds instead of requiring option or shift keys to be held while pressing a key.

Special features

SYM layer on keyboard.

SYM layer on keyboard.

CODE Layer

Streamlines code entry by mapping common syntax and command line elements such as:

Additional features

CODE layer on keyboard.

CODE layer on keyboard.

FN Layer

Photograph of keyboard and trackball on desk.

Photograph of keyboard and trackball on desk.

Special keys

Various MEH2 combinations are available on the left hand, which are used for in-app commands (primarily used in Lightroom when activating the FN layer through the L.FN key, not the momentary activation provided by holding T)

Keycaps & switches

Keycaps

Most of the keycaps are from the awesome Susuwatari set by MATT30, which uses the MT3 profile. It has a look and feel that reminds me of an old terminal keyboard. I wanted the shiny look of those old keycaps, so I polished the Susuwatari keycaps to have a nice, smooth feel of old, worn keycaps.

The SPACE and ENTER keys use G20 keycap profiles, so they’re extremely low-profile and only have a slight angle toward my thumb. This allow my thumb to rest slightly lower than the other fingers, providing more ergonomics.

Some of the keys are mounted sideways to better accommodate the shape of my hand and the angle of attack when pressing a key. Since I only ever use my thumb for the K key, the keycap is mounted upside down to improve comfort. The option and command keys on the left hand are at different orientations to allow differentiation by feel alone.

Switches

All switches have been hand-lubed for the best sound and feel and after a few years in use, all the keys are buttery-smooth with no scratchiness or spring ping.

Future plans

Conclusion

This keyboard layout significantly reduces hand strain while improving typing speed and workflow efficiency for developers. By incorporating multiple layers, intuitive combos, a leader key for launching apps, and META keys for in-app shortcuts, this layout is an advanced solution for programmers seeking ergonomic and rapid input solutions.

Hands down, though, the switch to Colemak-DH has been the biggest improvement to my keyboard setup. Even on my laptop, I notice less strain on my hands.


  1. HYPER is shorthand for SHIFT++++P; for example HYPER+P is SHIFT++++P ↩︎

  2. MEH is shorthand for SHIFT++; for example MEH+P is SHIFT+++P ↩︎