keychron_qmk_firmware/layouts/community/split_3x6_3/bcat
James Young c66df16644
2020 November 28 Breaking Changes Update (#11053)
* Branch point for 2020 November 28 Breaking Change                                                

* Remove matrix_col_t to allow MATRIX_ROWS > 32 (#10183)                                           

* Add support for soft serial to ATmega32U2 (#10204)                                               

* Change MIDI velocity implementation to allow direct control of velocity value (#9940)            

* Add ability to build a subset of all keyboards based on platform.                                

* Actually use eeprom_driver_init().                                                               

* Make bootloader_jump weak for ChibiOS. (#10417)                                                  

* Joystick 16-bit support (#10439)                                                                 

* Per-encoder resolutions (#10259)                                                                 

* Share button state from mousekey to pointing_device (#10179)                                     

* Add hotfix for chibios keyboards not wake (#10088)                                               

* Add advanced/efficient RGB Matrix Indicators (#8564)                                             

* Naming change.                                                                                   

* Support for STM32 GPIOF,G,H,I,J,K (#10206)                                                       

* Add milc as a dependency and remove the installed milc (#10563)                                  

* ChibiOS upgrade: early init conversions (#10214)                                                 

* ChibiOS upgrade: configuration file migrator (#9952)                                             

* Haptic and solenoid cleanup (#9700)                                                              

* XD75 cleanup (#10524)                                                                            

* OLED display update interval support (#10388)                                                    

* Add definition based on currently-selected serial driver. (#10716)                               

* New feature: Retro Tapping per key (#10622)                                                      

* Allow for modification of output RGB values when using rgblight/rgb_matrix. (#10638)             

* Add housekeeping task callbacks so that keyboards/keymaps are capable of executing code for each main loop iteration. (#10530)

* Rescale both ChibiOS and AVR backlighting.                                                       

* Reduce Helix keyboard build variation (#8669)                                                    

* Minor change to behavior allowing display updates to continue between task ticks (#10750)        

* Some GPIO manipulations in matrix.c change to atomic. (#10491)                                   

* qmk cformat (#10767)                                                                             

* [Keyboard] Update the Speedo firmware for v3.0 (#10657)                                          

* Maartenwut/Maarten namechange to evyd13/Evy (#10274)                                             

* [quantum] combine repeated lines of code (#10837)                                                

* Add step sequencer feature (#9703)                                                               

* aeboards/ext65 refactor (#10820)                                                                 

* Refactor xelus/dawn60 for Rev2 later (#10584)                                                    

* add DEBUG_MATRIX_SCAN_RATE_ENABLE to common_features.mk (#10824)                                 

* [Core] Added `add_oneshot_mods` & `del_oneshot_mods` (#10549)                                    

* update chibios os usb for the otg driver (#8893)                                                 

* Remove HD44780 References, Part 4 (#10735)                                                       

* [Keyboard] Add Valor FRL TKL (+refactor) (#10512)                                                

* Fix cursor position bug in oled_write_raw functions (#10800)                                     

* Fixup version.h writing when using SKIP_VERSION=yes (#10972)                                     

* Allow for certain code in the codebase assuming length of string. (#10974)                       

* Add AT90USB support for serial.c (#10706)                                                        

* Auto shift: support repeats and early registration (#9826)                                       

* Rename ledmatrix.h to match .c file (#7949)                                                      

* Split RGB_MATRIX_ENABLE into _ENABLE and _DRIVER (#10231)                                        

* Split LED_MATRIX_ENABLE into _ENABLE and _DRIVER (#10840)                                        

* Merge point for 2020 Nov 28 Breaking Change
2020-11-28 12:02:18 -08:00
..
config.h
keymap.c
readme.md
rules.mk 2020 November 28 Breaking Changes Update (#11053) 2020-11-28 12:02:18 -08:00

bcat's split 3x6 + 3 thumb keys layout

This is my favorite split ergo layout for typing, featuring the traditional four ortho/ergo layers (Default, Lower, Raise, Adjust). It is loosely inspired by the default Planck (numbers on Lower, symbols on Raise) and Crkbd (Space on left, Enter on right) layouts, but has since been redesigned heavily according to the principles described below.

  • Since my most-frequently-used keyboard shortcuts involve Ctrl, which lives on the left half of the keyboard, keys frequently used with it (numbers, function keys, etc.) are on the Raise layer activated by the right thumb.

  • Navigation can be done on the right half alone, to enable simultaneous left-handed mousing. Additionally, Web pages can be scrolled with Space or Shift+Space on the left half alone, to enable taking notes with the right hand at the same time.

  • Other than Right Shift (which I seldom use), mods aren't rebound on layers.

  • Likewise, Backspace is not rebound on layers to avoid having to let go of layer-switch keys to correct mistakes.

Default layer

Default layer layout

(KLE)

  • The alpha keys are a standard QWERTY layout, no funny business there.

  • Tab and Backspace are in familiar locations from my row-staggered boards (almost all of which use HHKB-style split backspace).

  • The Esc key is next to the home row for convenience in Vim.

  • There are two Shift keys, although I generally use Left Shift. (I've considered replacing Right Shift with another key, but haven't chosen one.)

  • Lower and Raise layer-switch keys are in the resting position of my left and right thumbs, respectively.

  • Space and Enter are on the big thumb keys so they're easy to press.

  • Ctrl is on the left for ease of chording, especially one-handed use of common shortcuts like Ctrl+T and Ctrl+W. This puts Alt on the right by the process of elimination. (I would really like one more 1U thumb key on each half to allow for a redundant Alt key on the left and a dedicated Super key on the right.)

Lower layer

Lower layer layout

(KLE)

  • This could also be called the "symbol layer".

  • Shifted numbers are bound in their usual positions on the top row.

  • Hyphen/Underscore and Equals/Plus are in the right index- and middle-finger columns for easy reach. They share the same relative position as on a row-staggered keyboard, and the shifted versions are physically above the unshifted versions as a mnemonic device.

  • Brackets and braces are placed below the parens for easy recall. Once again, the shifted versions are on the home row and the unshifted versions are on the bottom row.

  • Forward Slash/Pipe and Backtick/Tilde fill out the remaining positions on the right half, with the same relative positions as on a row-staggered HHKB layout. And yup, the shifted versions are above the unshifted versions.

  • Remaining keys from a TKL are placed out of the way on the bottom row of the left half.

  • The home row on the left half contains handy shortcuts for zooming and browser navigation.

  • Lower+Esc is bound to Ctrl+Space because the Ctrl and Space keys are both on the left thumb, so this key combination (which I use for tmux prefix and editor autocomplete) is hard to press in its natural location.

  • Lower+Tab is bound to a custom Alt+Tab macro that keeps the Alt modifier held as long as the Lower key is held down. This means that window switching is on Lower+Tab immediately next to browser tab switching (Ctrl+Tab).

Raise layer

Raise layer layout

(KLE)

  • This could also be called the "number layer".

  • Unshifted numbers are bound in their usual positions on the top row.

  • Arrow keys are on VIM-style HJKL keys.

  • Home/End and Page Up/Page Down are in the same column as the arrow keys, but translated down one row. (This means that the comma and period keys are not bound on the number layer, which makes data entry a bit funky. I might add a dedicated numpad layer to compensate.)

  • Function keys F1F10 take up most of remaining space on the left half, with F11 and F12 spilling over to the right half. (This puts the most used function keys (F1F5) on the home row.)

  • Insert and Delete are on the rightmost column, because there didn't seem to be a better place to put them.

  • Caps Lock is bound in the same position as on an HHKB, for lack of an obvious better location.

Adjust layer

Adjust layer layout

(KLE)

  • Media keys are centered around the ESDF cluster, just like I arrange them on row-staggered keyboards. (It's even more sensible with columnar stagger.)

  • The navigation keys are replaced by RGB controls. Again, this mirrors the positioning I use on my row-staggered keyboards.

  • Finally, reset keys live at the top-left corner of the right half where it's reasonably hard to press them by accident.