Dactyl Manuform 5x6 programmable ergonomic keyboard

Suraj N. Kurapati

Photograph of my Dactyl Manuform 5x6 keyboard.


DEPRECATED: This has been superseded by the MoErgo Glove80 keyboard.

NOTE: Check out the interactive layer map for this keyboard below!


This is my Dactyl Manuform keyboard: specifically, a 5-row and 6-column (5x6) variant manufactured by Ergohaven that I fitted with colorful Rainbow keycaps, tactile brown key-switches, and enhanced firmware with legendary Miryoku design.

Video: Introduction to the Dactyl Manuform keyboard.

Click to watch video

Prior to this, I used an ErgoDox EZ keyboard for 6 years and then a Kinesis Advantage keyboard for 11 years before that. All of these have a shared lineage: the Advantage has contoured keywells but isn’t split, the ErgoDox is split but isn’t contoured, and the Dactyl has the best of both: it’s split and contoured!

  1. Layers
    1. Cursor layer
      1. Arrow keys
        1. Select & edit
        2. Number layer
          1. Prefix signs
            1. Date & time
              1. Inequalities
              2. Function layer
                1. Symbol layer
                  1. Base layer affinity
                    1. Vim editor shortcuts
                      1. Adjacent key bigrams
                        1. Outer corner bigrams
                          1. Inward rolling bigrams
                            1. Outward rolling bigrams
                            2. Mouse layer
                              1. Light layer
                              2. Firmware
                                1. Extra QMK patches
                                  1. QMK configurator app
                                    1. Building the firmware

                                    Layers

                                    The keyboard boots up into the following default “base” layer when powered on. When held, the purple keys in the thumb clusters activate the subsequent layers according to the legendary Miryoku’s 6-layer design with 3-key thumb activation.

                                    Interactive: Hover your mouse over the purple keys to see each layer!

                                    The keys are arranged in my variation of Arno Klein’s Engram 2.0 layout and they’re imbued with the legendary Miryoku home row mods tamed with enhancements.

                                    Cursor layer

                                    Diagram of the cursor layer.

                                    Arrow keys

                                    The up/down arrow keys on the right-hand home row diverge from Vim’s HJKL order because it feels more natural to follow the inward-rising curve of the keyboard’s contoured keywell, which elevates the thumb above the pinky finger and, similarly, the middle finger (up arrow) above the ring finger (down arrow).

                                    This is a longstanding preference that I formed 17 years ago, in my early days of using the Kinesis Advantage with the Dvorak layout, whose lack of HJKL provided the freedom to reimagine the arrangement of arrow keys on the home row.

                                    Select & edit

                                    Editing and selection keys line the outer edges of the home block, respectively. This opposition enables inward rolls, where selections can be followed by edits. For example, to copy everything, I would first tap the “Select all” key with my pinky finger and then roll inward to tap the “Copy” key with my index finger.

                                    The copy and paste keys are stacked vertically, in that order, to allow the index finger to rake down upon them in a natural curling motion toward the palm. This order is also logical, since pasting requires something to be copied first.

                                    The versatile “Select word/line” key at the right edge of the home row is powered by Pascal Getreuer’s word selection QMK macro, which automates common selection tasks that require holding down Control and Shift with the arrow keys:

                                    Video demonstration of Pascal Getreuer's word selection QMK macro

                                    Tapping it selects the word under the cursor; shift-tapping it selects the line. Further taps extend the selection by another word (unshifted) or line (shifted).

                                    Number layer

                                    Diagram of the number layer.

                                    A 3x3 numeric keypad (using the standard 10-key layout) occupies the home block. The period key is poised to be tapped using the metacarpal joint of the thumb, allowing the thumb to rest on the zero key, ready for more numerical data entry.

                                    Prefix signs

                                    Signs that commonly prefix numbers are positioned above the 3x3 numeric keypad.

                                    Date & time

                                    The slash and minus keys are positioned for MM/DD and YYYY-MM-DD date entry. Similarly, the colon key is positioned above them for HH:MM:SS time stamp entry.

                                    Inequalities

                                    Comparison operators are positioned along the outer left edge of the home block.

                                    The greater/equals keys are stacked vertically, in that order, to allow the index finger to rake down upon them in a natural curling motion toward the palm.

                                    Function layer

                                    Diagram of the function layer.

                                    The function keys are arranged in the same 10-key layout as the Number layer’s 3x3 numeric keypad so that you can develop common muscle memory for both layers. The remaining F10-F12 keys wrap around the home block because they’re found in shortcuts such as BIOS save/quit, fullscreen toggle, and devtools, respectively.

                                    Symbol layer

                                    This is the crown jewel of my keyboard’s configuration: an entire layer dedicated to the entry of symbols that are essential for computer programming. It’s the result of several hundreds of layout iterations over the last 8+ years.

                                    Diagram of the symbol layer.

                                    👉 Red groups. Blue quotes. Yellow Vim. Green arrows. Purple flips.

                                    Base layer affinity

                                    Vim editor shortcuts

                                    Adjacent key bigrams

                                    Outer corner bigrams

                                    These are easy to find because they’re on the outer corners of the keyboard.

                                    Inward rolling bigrams

                                    Outward rolling bigrams

                                    Mouse layer

                                    Diagram of the mouse layer.

                                    Movement keys are located centrally in the home block, resembling WASD keys, and mouse acceleration controls are poised for pinky finger access, so you can independently move the mouse pointer and also change its speed at the same time.

                                    Mousewheel down/up keys are also placed on the home block, specifically on the same keys as J/K (down/up in Vim) on the base layer for muscle memory reuse.

                                    Light layer

                                    Diagram of the light layer.

                                    Keys for lowering/raising light settings line the central columns of home block, whereas keys for applying lighting modes line the outer edges of the home block.

                                    Firmware

                                    My keyboard’s entire QMK firmware configuration, as described in this article, is made available on GitHub in the sunaku_dm5x6 branch of my personal QMK fork.

                                    ~/qmk_firmware/keyboards/handwired/dactyl_manuform/5x6_5/keymaps/sunaku/
                                    ├── config.h
                                    ├── features -> getreuer/features
                                    ├── getreuer/
                                    ├── keymap_config.json
                                    ├── keymap_footer.c
                                    ├── keymap_header.c
                                    ├── Makefile
                                    ├── README.md
                                    └── rules.mk
                                    

                                    Extra QMK patches

                                    This configuration includes additional enhancements on top of the standard QMK:

                                    1. My crossover bilateral combinations patch, used for Miryoku home row mods.
                                    2. Pascal Getreuer’s word selection QMK macro, utilized in the cursor layer.

                                    QMK configurator app

                                    You can upload the provided QMK Keymap JSON file named keymap_config.json into the QMK Configurator app to view or customize the keymap and all of its layers. When you’re finished, download the keymap back to the same file, overwriting it.

                                    Building the firmware

                                    Navigate into the directory shown in the Firmware section above and run make to:

                                    1. Convert the keymap_config.json file into C source code.
                                    2. Wrap the C source code with a custom header and footer.
                                    3. Compile the wrapped up C source code using qmk compile.
                                    4. Flash the compiled firmware (HEX file) to the keyboard.

                                    All these steps are handled by the provided Makefile, shown below for reference:

                                    # NOTE: Don't name the QMK Configurator JSON keymap file as "keymap.json"
                                    # because `qmk compile` directly translates it into C and compiles it too,
                                    # thereby completely bypassing this Makefile and our keymap header/footer!
                                    
                                    TOPLEVEL=`git rev-parse --show-toplevel`
                                    KEYBOARD=handwired/dactyl_manuform/5x6_5
                                    KEYMAP=sunaku
                                    
                                    all: flash
                                    
                                    flash: build
                                    	    qmk flash -kb $(KEYBOARD) -km $(KEYMAP)
                                    
                                    build: keymap.c config.h rules.mk
                                    	    test ! -e keymap.json # see comment at the top of this Makefile
                                    	    qmk compile -kb $(KEYBOARD) -km $(KEYMAP)
                                    
                                    keymap.c: keymap_config.json keymap_header.c keymap_footer.c config.h
                                    	    qmk json2c -o $@ $<
                                    	    spot=$$( awk '/THIS FILE WAS GENERATED/ { print NR-1 }' $@ ) && \
                                    	    sed -e "$$spot r keymap_header.c" -e "$$ r keymap_footer.c" -i $@
                                    
                                    clean:
                                    	    qmk clean
                                    
                                    clobber: clean
                                    	    rm -fv keymap.c
                                    	    rm -fv $(TOPLEVEL)/$$( echo $(KEYBOARD) | tr / _ )_$(KEYMAP).hex
                                    
                                    .PHONY: clean clobber build flash