July 2023: v95 new option to include/exclude specific keyboards, see IncludeDeviceId
December 2022: Windows 11 update 22H2 breaks minimize to tray, see Wiki for a fix
Keyboard configuration tool that re-maps keys and modifier-key-combos at a very low level.
Created for productivity and fast keyboard layout prototyping, but also works for gaming.
(Might be useful to work around handicaps, but I have no experience. Open an issue if you need a special feature).
Uses the Interception driver to receive keys before almost everyone else.
- Latest release
- Install guide
- Manual
- Readme contents
I touch type. I code. I need a keyboard setup where I can keep my fingers on the home row most of the time.
Also, my layout cured my RSI, and I'm a seriously fast coder/editor on any keyboard (and I never need to learn non-standard laptop keyboards).
Earlier versions were very focused on my own configuration. Latest versions are fully configurable.
-
It just works. Everywhere.
- Like a hardware programmable keyboard, Capsicain can view and remap key strokes before anyone else does.
-
Can remap every key that is sent out by the keyboard. (Excptions: 'media keys' that are not registered as keypresses, and the ESC key).
-
Almost everything is configurable via config file.
- Nine separate configs, switch with
ESC
+<1-9>
. - Modular config with
INCLUDE moduleXY
.
- Nine separate configs, switch with
-
Modifier remapping
-
Examples:
F
andJ
toShift
,CapsLock
toMOD9
,LCtrl
toReturn
, RotateAlt
>Shift
>Ctrl
>Alt
. -
If it sends a scancode, you can remap it.
-
-
Powerful modfier combos
- Can do keycombos with all 15 modifiers with a single one-liner rule.
- Combine Modifier-Down, Modifier-NOT-down, Modifier-A-OR-B-down, Modifier-tapped in one combo.
-
Simple, fast and pretty alpha key mapping, to define Workman, Colemak, Dvorak, or play with your own layout.
- Changing a key position is one character in the .ini file, [ESC]+[R] to reload and you're live.
-
Dead key system to define your own äççéñtèd characters.
-
Sequences (key macros) with configurable delay between keys.
- On the fly recording and playback of macros.
- Secret macros that are only stored, obfuscated, in memory
-
Fast. Low-fat C/C++ code. 1 exe 1 dll 1 ini. Never writes, only reads inside its folder.
This is the config I use myself. I call it the King Configuration, because, like the King in Chess, fingers must never move more than one key from their base position into any direction to write and edit any text. (Exceptions: Escape, Enter, app-specific combos that I have not considered).
-
Hold
CapsLock
+ right hand keys -> Cursor control layer. I LOVE this!!Key Pressed Result I
J
K
L
(Cursor) ↑
←
↓
→
Z
U
Home
End
H
Backspace
etc etc -
Hold
CapsLock
+ left hand keys -> Standard Ctrl-CombosKey Pressed Result A
S
D
F
G
Undo
Cut
Copy
Paste
Redo
Q
W
E
R
SelectAll
GotoTop
Find
FindNext
Z
X
C
V
NewFile
NewTab
Open
Save
CloseTab
-
Hold
TAB
+ right hand -> NumPad layerKey Pressed Result U
I
O
7
8
9
J
K
L
4
5
6
etc etc -
ALT
+ letter keys-> all regular symbol characters.ALT
+Q
for '!' is an easier combo than Shift + 1, when you get used to it.- Layout equivalent:
! @ # $ % ^ & ( ) ü ß - + * / = \ { } ö ä ` ~ | _ … < > [ ] ...
-
Tap
ALT
,<key>
-> Special character layer
€ © ° ¹²³ ...
-
Tap
ALT
,<deadkey>
,<basekey>
-> Special deadkey sequencesKeystrokes Result ~
,n
ñ
~
,a
ã
^
,a
â
-
Tap
Caps
, TapALT
,Shift
+<key>
-> Uppercase greek characters- Σ (just because I can)
-
TAB
(NumPad) +Ctrl
+Number
-> "Table" characters┌────────────────────────┐ │ I like these things :) │ └────────────────────────┘
-
TAB (NumPad) + Ctrl + Shift + Number -> "Fat Table" characters
╔═════════════════════╦═══╦══╗ ║ MOAR TABELS!! ╠═══╬══╣ ╚═════════════════════╩═══╩══╝
An AHK script must run that catches
F14
/F15
key combos.-
10 Clipboards
Caps
+<0-9>
copies to clipboard #n
TapCaps
,<0-9>
pastes from clipboard #n
-
Start my apps with centrally configured hotkeys
-
Windows control shortcuts: maximize, minimize, restore, close
-
-
These talk directly to Capsicain, trigger them with
ESC
+<key>
Key Pressed Result X
eXit capsicain H
Help - list available commands <1-9>
Switch configs 0
Switch to empty (disabled) config -
There are various other options, like "flip Z/Y", "flip WIN/ALT on Apple keyboards", timing for macros, status, more.
ESC
+X
Exits, always, in case your config makes the keyboard unusable. Capsicain doesn't have to be in the foreground to seeESC
command combos.ESC
+0
Switch to Config 0 is the softer 'disable' method; it tells Capsicain to not do anything - except listen forESC
combos, so you can switch back to your Config 1 later.- The wiki has information on most edits you can do
-
-
AutoHotkey is nice, did it for 10 years, but it runs in userspace and fails whenever the target gets key input from low level (VMs, RDP fullscreen, security boxes, games). It is limited when comes to multi-modifier combos. I still use it as a deputy for capsicain, doing Windowsy userspace tasks.
-
Windows Keyboard Layout Creator works more reliable, but it supports only very basic key remapping, and requires a reboot for every change.
-
Karabiner is really good, but Mac-only.
-
Tmk / Qmk with Hasu's Usb-to-Usb stick is very cool, but it cannot do laptop keyboards.
-
Capsicain does everything I want, the way I want it.
-
-
- Beer made me do it. I like chilis. This tool defines a lot of CapsLock Hot keys. 'Capsaicin' is the chemical stuff that makes chilis hot, Capsicain just has a better flow to it (and is a unique name. Although that was a mistake - google search still says You Fool! You Spelled capsaicin wrong!)
-
- v1..12 was created in the capsicain_interception repo. This was an experimental non-VS project, now obsolete, except for the history.
-
- This is the layout I use by default, you can either use
ESC
+Z
to flip Y/Z, or edit the config to disable this switch
(in capsicain.ini section[CONFIG_1]
, comment outINCLUDE LAYOUT_QWERTZJ
)
- This is the layout I use by default, you can either use
-
-
Interception is the driver that allows capsicain to intercept and modify keyboard events.
Long version
This is a signed driver ("keyboard driver upper filter"), another project on github. It must be installed for capsicain to work. It provides a DLL to interface with the driver.The filter driver does nothing (just forwards all key events from the keyboard driver to the next driver in the chain) unless a client wants to hook into the keyboard events.
The DLL is free and open source, the driver is free but closed source (sources available for $1000. The guy wants to make some money from commercial projects - I hope he does because he did some really good work here).
Musings: Capsicain is a normal userspace app, which means you can simply start and stop it anytime. It also means it cannot talk to the keyboard driver directly, so it needs the Interception driver. This is an unavoidable complication in Windows 10, but I actually see it is a good thing: because it is not that easy, no normal application or game will do this - and this means that Capsicain is always #1 in the keyboard processing chain.
-
-
- capsicain is completely open source. It does not write to disk, it does not do any networking.
- The Interception driver is closed (pay for) source, but it is an established project, and after looking into it, it all seems legit to me.
- Reading keyboard input is possible with any binary you run with admin privileges, this caution should be applied universally.
-
- Double-taps are not configurable
- No combos-to-modifier (Ctrl+X -> Alt). Useless?
- Windows ALT-Numpad combos for special characters ╠═ö€Σε═╣ don't work in Linux VMs.
- If you need this, you have to create your own config for Linux special chars.
- Cannot be triggered by other software. Capsicain listens to the keyboard hardware and nothing else.
Feel free to open an issue to ask questions.
I'm willing to help, and interested in ideas.
You're also welcome to start a discussion