Remapping Keyboard Keys on Mac OS X Mavericks
This is an updated version of my original guide on how to remap keyboard keys on OS X.
Here’s how to remap any of your keyboard keys to any combination of keys on Mac OS X. Initially, I wanted to remap the Caps Lock
key to Command+R
for two reasons:
- I’m always hitting
Command+R
for building and running iOS apps and to refresh web pages Caps Lock
is otherwise entirely useless
Here are the steps and workarounds I used to get what I wanted. I’ve essentially remapped the Insert
, Home
, Page Up
, Delete
, End
and Page Down
, and Caps Lock
keys into a useful macro block.
- Download the latest version of KeyRemap4MacBook; it’s pretty much the only decent key remapper for Mac. Despite its horrible name, it is insanely flexible and powerful.
- Install KeyRemap4Macbook as per the instructions on their website.
- Download PCKeyboardHack if you want to remap the
Caps Lock
key. - Open PCKeyboardHack (from the Launchpad), and under the Caps Lock section select Change Caps Lock.
- Change the
keycode
in the right hand column to ‘110’. - Open KeyRemap4MacBook from
~/Applications
. - Scroll down to ‘For PC Users’, expand it, expand ‘Change PC Application Key’.
- Select whatever key you want the Caps Lock key to remap to (I set it to ‘Application Key to Command_L’).
Not exactly perfect, right? There’s a very limited selection of keys you can remap to. Don’t worry, with a little .xml hacking we can get it to do what we want (in a way). For those of you who are happy to just use it like this, don’t worry about the next bit. For this section, we are going to introduce user-defined key remapping.
- In KeyRemap4MacBook click ‘Misc & Uninstall’ in the top tab bar.
- Click ‘Open private.xml’ to open it in Finder.
- Open the
private.xml
file in TextEdit. - Open this private.xml file in your browser. Copy and paste the code from this remote file to replace the contents of the local
private.xml
file. -
The basic syntax for adding a new remapping is this:
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters<item> <name>SOMENAME</name> <identifier>private.some_name</identifier> <autogen>--KeyToKey-- KeyCode::STARTKEY, KeyCode::DESTINATIONKEY</autogen> </item> - Replace
STARTKEY
with some key from this list. Make sure you use the uppercase name in the left column to replaceKEYTOSTART
. (KeyCode::
must be left as it is.) -
As an example, here is what I used to remap
Caps Lock
(i.e.PC_APPLICATION
) toCommand+R
:This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode characters<item> <name>CAPSLOCKTOCMDR</name> <appendix>this is to remap caps lock to cmdR</append> <identifier>private.swap_capslock</identifier> <autogen> --KeyToKey-- KeyCode::PC_APPLICATION, KeyCode::R, ModifierFlag::COMMAND_L </autogen> </item> - Save the
private.xml
file. - Go back to KeyRemap4MacBook and hit ‘ReloadXML’ and your newly defined remaps should appear at the top of the list.
- Select the one you want.
- Try it out.
- Look through this page for more comprehensive documentation of what you can achieve.
- Keep defining new remaps until you’ve got exactly what you want.
So, eventually, we worked out a way to remap any key we want to another key or combination of keys. It works really well, and it’s probably good for RSI or something. At the very least, we’ve satisfied our laziness.
For anyone interested, here is my full private.xml
file:
<?xml version="1.0"?> | |
<root> | |
<item> | |
<name>Swap Space and Tab</name> | |
<identifier>private.swap_space_and_tab</identifier> | |
<autogen>--KeyToKey-- KeyCode::SPACE, KeyCode::TAB</autogen> | |
<autogen>--KeyToKey-- KeyCode::TAB, KeyCode::SPACE</autogen> | |
</item> | |
<item> | |
<name>My Excel Hacks (effective only on Excel)</name> | |
<appendix>Change Command+2 to Ctrl+U</appendix> | |
<appendix>Change Control+A to Home</appendix> | |
<appendix>Change Control+E to End</appendix> | |
<identifier>private.app_excel_command2_to_ctrlu</identifier> | |
<only>EXCEL</only> | |
<autogen>--KeyToKey-- KeyCode::KEY_2, VK_COMMAND, KeyCode::U, ModifierFlag::CONTROL_L</autogen> | |
<autogen>--KeyToKey-- KeyCode::A, VK_CONTROL, KeyCode::HOME</autogen> | |
<autogen>--KeyToKey-- KeyCode::E, VK_CONTROL, KeyCode::END</autogen> | |
</item> | |
<item> | |
<name>My TrackPad LeftClick Hack</name> | |
<appendix>Command+LeftClick to F12 (only on MacBookPro2,1 Trackpad)</appendix> | |
<identifier>private.pointing_leftclick2f12_trackpad</identifier> | |
<device_only>DeviceVendor::APPLE_COMPUTER,DeviceProduct::APPLE_INTERNAL_KEYBOARD_TRACKPAD_0x021a</device_only> | |
<autogen>--PointingButtonToKey-- PointingButton::LEFT, VK_COMMAND, KeyCode::F12</autogen> | |
</item> | |
<item> | |
<name>CAPSLOCKTOCMDR</name> | |
<appendix>this is to remap caps lock to cmdR</append> | |
<identifier>private.swap_capslock</identifier> | |
<autogen> | |
--KeyToKey-- | |
KeyCode::PC_APPLICATION, | |
KeyCode::R, ModifierFlag::COMMAND_L | |
</autogen> | |
</item> | |
<item> | |
<name>PGDOWNTOCMDZ</name> | |
<appendix>this is to remap pgdown to cmdz</append> | |
<identifier>private.swap_pgdown</identifier> | |
<autogen> | |
--KeyToKey-- | |
KeyCode::PAGEDOWN, | |
KeyCode::Z, ModifierFlag::COMMAND_L | |
</autogen> | |
</item> | |
<item> | |
<name>endTOCMDs</name> | |
<appendix>this is to remap end to cmds</append> | |
<identifier>private.swap_end</identifier> | |
<autogen> | |
--KeyToKey-- | |
KeyCode::END, | |
KeyCode::S, ModifierFlag::COMMAND_L | |
</autogen> | |
</item> | |
<!-- ============================================================ --> | |
<!-- An example of appdef --> | |
<appdef> | |
<appname>APPSTORE</appname> | |
<equal>com.apple.appstore</equal> | |
</appdef> | |
<item> | |
<name>Space to Tab on App Store.app</name> | |
<identifier>private.appdef</identifier> | |
<only>APPSTORE</only> | |
<autogen>--KeyToKey-- KeyCode::SPACE, KeyCode::TAB</autogen> | |
</item> | |
<!-- ============================================================ --> | |
<!-- An example of devicevendordef,deviceproductdef --> | |
<devicevendordef> | |
<vendorname>HEWLETT_PACKARD</vendorname> | |
<vendorid>0x03f0</vendorid> | |
</devicevendordef> | |
<deviceproductdef> | |
<productname>MY_HP_KEYBOARD</productname> | |
<productid>0x0224</productid> | |
</deviceproductdef> | |
<item> | |
<name>Space to Tab on MY_HP_KEYBOARD</name> | |
<identifier>private.deviceproductdef</identifier> | |
<device_only>DeviceVendor::HEWLETT_PACKARD, DeviceProduct::MY_HP_KEYBOARD</device_only> | |
<autogen>--KeyToKey-- KeyCode::SPACE, KeyCode::TAB</autogen> | |
</item> | |
<!-- ============================================================ --> | |
</root> |
For more information on the full power of the private.xml
file, check out the reference manual (thanks to @jnlevitan for the tip).
I’d love to hear your favourite key remappings, feel free to share them with me on Twitter.
💅 Vanilla – hide icons from your Mac menu bar for free
🚀 Rocket – super-fast emoji shortcuts everywhere on Mac… :clap: → 👏
⏳ Horo – the best free timer app for Mac
📂 FastFolderFinder – a lightning-fast launchbar app for folders and apps
📖 Kubernetes – my book on Kubernetes for web app developers
😄 Emoji Bullet List – easily emojify your bullet point lists (like this one!)
Jump on my email list to get sent the stuff that’s too raunchy for the blog.
(Seriously though, it’s an occasional update on apps I’ve built and posts I’ve written recently.)