bbc3bc55f2 | ||
---|---|---|
.. | ||
config.h | ||
keymap.c | ||
readme.md | ||
rules.mk |
readme.md
Othi's Universal HHKB keymap
Goals
-
Colemak layout. If you don't use Colemak then you'll need to also change the arrow key bindigns in other layers
-
Vim-like navigation layer so you can use vim binding arrowkeys in non-vim environment
-
Good modifier support so you don't have to hold 14 modifier keys at the same time
-
RGB indicating layer change(only work with plain colors so far, don't put your rgb to pulsing or any non static animation)
Layers
-
CL:
The base layer, default is Colemak
-
NM_MODE:
Vim-like arrowkeys in the home row, it's
LHNE
for JENK Colemak andHJKL
for QWERTYAlso
HOME
,END
and next/prev word (Ctrl + Left/Right
) in0, 4, w, b
like in vim -
VI_MODE:
The same as
NM_MODE
but withKC_LSFT
held down for mostly highlighting -
ACCENT + ACCENT_CAP:
Function row and Unicode characters
Modifiers and Tap Dance keys
LHS:
-
Any Tap Dance key with the format of
TD(XXX_NM)
act as normal XXX modifier upon hold, but will hold and put you toNM_MODE
when double click hold(a tap before the hold)(eg you can produceAlt + PgUp
by pressingAlt + Alt + U
) -
KC_TAB
acts as bothKC_TAB
on tap andKC_LGUI
on hold -
R3 CapsLock acts as both
KC_BSPC
on tap andKC_LCTL
on hold -
Holding
KC_Q
also puts you intoNM_MODE
-
Holding
KC_F
puts you intoVI_MODE
for fast function keys
RHS:
-
3 keys
KC_SCLN
,KC_DOT
andKC_SLSH
inCL
layer can also be held down for respectivelyKC_LCTL
,KC_LSFT
,KC_LALT
for easier 2-hand modifier holding -
Right modifiers hold the selected modifier with
KC_LGUI
at the same time, mainly for i3wm, you can change this to whatever combination you want
Misc. functionalities
Unicode:
-
In case the keyboard output the 4-digit codepoint instead of the actual unicode, you need to change the rewrite input mode of the keyboard into the EEPROM(you only have to do this if the EEPROM was cleared or your current machine use another unicode compose method other than IBus/Linux's
Ctrl + Shift + U
). Change the corresponding Inputvoid eeconfig_init_user(void)
. See this for availble input modes. -
NOTE: make sure to keep your qmk env up to date with upstream