This is a text-only version of the following page on https://raymii.org:
---
Title       :   Relegendable keycaps for your macropad, the best thing ever for developer productivity
Author      :   Remy van Elst
Date        :   06-09-2021
URL         :   https://raymii.org/s/blog/Relegendable_keycaps_for_your_macropad.html
Format      :   Markdown/HTML
---



![macropad combo][15]

> My current macropads

As you might know, I've got [a weird keyboard][1]. It is an Ergodox EZ, it's
split up in two halves and for me it's the best thing ever to combat RSI.
I've also got a weird mouse, a left handed vertical mouse, for the same
reason. Even 15 minutes on a regular setup and my wrists and shoulders hurt.
The next best thing is my standing desk and number three is having regular
breaks with small exercises. One downside to the Ergodox is that you have
[less keys][4] than on a regular keyboard. This is solved with layers, just
like when holding SHIFT or CTRL, a key does something different. SHIFT is the
layer for capital letters and symbols, with the Ergodox you can define your
own layers. I however cannot get used to layers, not even after 7 years of
using the Ergodox. Not a problem, I've got [an extra keyboard][2] in the
middle, next to my mouse, with 8 or 9 keys just for my most often used
shortcuts. It's called a macropad, one I've soldered myself and one I've
bought on a well-known Chinese webstore.


<p class="ad"> <b>Recently I removed all Google Ads from this site due to their invasive tracking, as well as Google Analytics. Please, if you found this content useful, consider a small donation using any of the options below:</b><br><br> <a href="https://leafnode.nl">I'm developing an open source monitoring app called  Leaf Node Monitoring, for windows, linux & android. Go check it out!</a><br><br> <a href="https://github.com/sponsors/RaymiiOrg/">Consider sponsoring me on Github. It means the world to me if you show your appreciation and you'll help pay the server costs.</a><br><br> <a href="https://www.digitalocean.com/?refcode=7435ae6b8212">You can also sponsor me by getting a Digital Ocean VPS. With this referral link you'll get $100 credit for 60 days. </a><br><br> </p>



One at work and one at home, both run QMK, firmware that allows me to program
the macropad with my own shortcuts. Recently a video from [Atomic Shrimp][3]
(awesome channel) showed off relegendable keycaps. Those are transparent
keycaps with an insert for your own label. Before I had relegendable keycaps,
I had regular keycaps for the macropad, for example, the `L` key sends
`CTRL+ALT+L` to lock the desktop. Now, with these awesome keycaps, I have a
dedicated `LOCK` key. This is such a big quality of life improvement,
especially when using the CLion debugger shortcuts. This post covers my
usage of the macropads, the re-legendable keycaps and shows you a few
pictures of the macropads, both before and after.

### Relegendable keycaps

[Atomic Shrimp][3] shared a powerpoint presentation with the exact
printable format for the keycaps. They're 13x13mm squares. You can
find my edited powerpoint [here][9]. Works great in LibreOffice.

Even though I know the keys on the macropad without keycaps, it still
helps to take off a bit of mental load when using the macropad. I mostly
use it when debugging C++ code, so my mind is very focused on the problem
I'm trying to solve, having to take a glance at my board and thinking,
was the `O` key for `Step Over` or for `Step Out`, (the `^` key is for
`Step Out`), breaks that flow. Now the keycaps are written out and have a
distinct colour. I even thought of printing the CLion debugger icons on
the labels, but that went a bit too far.

The `MUTE` key is a blessing as well during video calls. No need to hover over
the teams window and click a button, just press one key labelled `MUTE`.
Pressing it again unmutes. Small thing, but so enormously nice to have.

Locking my workstation? Just one big black key labeled `LOCK` instead of
finger gymnastics to get to `CTRL+ALT+L`.

It might be hard to get the message over in writing to you, but this macropad
has been a real productivity boost for me when debugging C++. The new keycaps
with descriptive labels are a step up on that productivity boost, having to
think even less, which means, keeping all focus on the problem I'm actually
working on.

The other big advantage is that you can change the labels later on. I have another
QMK firmware file just for use in Windows with Visual Studio for `.net` C sharp
development, with a few different keys like Live Reload, `ALT+F10`, Goto All (`CTRL+T`)
(comparable to Shift-Shift in CLion) and Run All Tests (`Ctrl+R, A`). One of the
RoMacs has special labels and has that firmware on it, so I can switch easily.

This is how a relegendable keycap looks, one bottom (key) part,
your printed label in between and a transparent cover on top:

![relegendable keycap][10]

The links in this post to MechBoards are not sponsored. I have not bought
anything there, they just happen to have nice listings with pictures.

### SpaceCat Launchpad v2

Here is a picture of the new keycaps on the Launchpad v2 macropad:

![launchpad after][7]

This is the layout:


    ,-------------------------.
    | RUN        | DEBUG      |
    |------------+------------|
    | STEP OVER  | STEP INTO  |
    |------------+------------|
    | STEP OUT   | RESUME     |
    |------------+------------|
    | PLAY/PAUSE | LOCK       |
    `-------------------------'

Tapping `PLAY/PAUSE` 2 times in a row makes it `Skip` a song. Double-tapping `RUN` acts as
the `MUTE` key combo (`CTRL+SHIFT+M`) for Microsoft Teams. QMK calls this a [Tap Dance][8].

The topmost 6 keys are all for use with the debugger in CLion, Jetbrains' C++
development environment. I could have put all those shortcuts on the Ergodox,
on a different layer, but as I said, I cannot get used to layers. In fact,
layer 4 has a bunch of CLion shortcuts and I never use them. One of my Ergodox
keys is mapped to `Refactor/Rename` (on the base layer) and I use that all the
time. The macropad is very visual and distinct, just for one purpose.

Before the relegendable keycaps, I had cobbled together keys that were as
descriptive as regular keys could be, `I` for `Step Into`, `R` for `Resume`,
but those keys all had a different height profile, a minor annoyance.

Here is the before picture:

![launchpad before][11]

This board was a kit, I [soldered it myself][2]. It seems that SpaceCat Design
has gone bust, since the site has a password login since late last year. At
first they mentioned a reopen date in June this year, but in July this year
that date was removed. A great alternative kit, I also have two, still for
sale is the [Romac Macropad][5]. Here is [a picture of the Romac][6] I found
online of someone else's board with relegendable keycaps. They have the different
layer symbols on there as well:

![romac keycaps][6]

I love the aesthetic of that board, the visible electronic components under the
transparent acrylic plate and just the overall cuteness. As said, I have two of
those via a group buy, I switch the macropads around every month or so, they all
have the same key combo's. At least, the 12 key RoMacs are the same as the YMD09
I'm describing below, with the bottom row unused (blank white caps).

### YMD09

The macropad I use at home was not a kit, I bought it pre-built for about EUR
15 on a well known chinese website. I'm not linking to it directly because if
I do that link will be dead in a month. You can search yourself or get the kit
version [here][12].  This board is way more fancy than the SpaceCat. It has
USB-C and it has RGB lighting.

Here is a picture of the macropad with relegendable keycaps:

![YMD09 after][13]

I couldn't care less about the RGB backlight but USB-C is nice. The Launchpad
(and RoMac) use an arduino micro clone, which has a well known issue with the
micro USB connector. I can snap off or become loose, which all of mine are.
Now you can easily replace the connector, but in my experience the USB-C connectors
don't have those problems. In new projects I do with an arduino, I now use
clones with USB-C exclusively due to that.

This is the layout:

    ,-------------------------------------.
    | RESUME     | STEP OUT   | MUTE      |
    |------------+------------|-----------|
    | STEP OVER  | RUN        | STEP INTO |
    |------------+------------|-----------|
    | LOCK       | PLAY/PAUSE | DEBUG     |
    .------------+------------|-----------,

It has one extra key more than the Launchpad, I've assigned a dedicated `MUTE` key.
The RoMac's share this layout as well. The middle `RUN` key has no special label
on the picture, but that was an error during printing and afterwards the all the paper
was used up, I fixed that later.

When the middle red key is held, the layer switches to a special layer which controls
the RGB lightning (intensity, colour and profile). I almost never use it, except to
reflash the board. It has one key that puts QMK into debug mode, allowing me to flash
new firmware.

Here is the before picture:

![ymd09 before][14]

As you can see, that was a hodgepodge of keys I had lying around. No uniform height
profile, the lightning bleeds out underneath and the keycaps are not remotely relatable
to their functions.

If you want your own macropad, I recommend you get a kit with through-hole components.
I find it fun to solder but SMD is just way too hard and small. The kits are cheaper
that a prebuilt board and most other AliExpress boards require special windows software
to configure it, often more limited than QMK. There are web based configurators for QMK
as well as `Via` (Windows GUI software) to key your keymap without compiling QMK yourself.
Check out `r/MechanicalKeyboards` on Reddit for the hottest macropad group-buy of the week,
or get one in stock at a store close to you and enjoy building the kit!


[1]: /s/articles/Split_keyboards_a_five_year_review_including_the_ErgoDox_EZ_Matias_Ergo_Pro_and_Kinesis_Freestyle_2.html
[2]: /s/articles/SpaceCat_Launchpad_v2_an_awesome_little_macropad.html
[3]: https://youtu.be/zMn6DPUre70
[4]: /s/articles/Gherkin_30_key_keyboard_build_log_and_review.html
[5]: https://mechboards.co.uk/shop/kits/romac-macro-pad
[6]: /s/inc/img/romac.png
[7]: /s/inc/img/mp-1-after.png
[8]: http://web.archive.org/web/20210906183733/https://beta.docs.qmk.fm/using-qmk/software-features/feature_tap_dance
[9]: /s/inc/downloads/legends.pptx
[10]: /s/inc/img/relegendable-keycap.png
[11]: /s/inc/img/mp-1-before.png
[12]: https://mechboards.co.uk/shop/kits/ymd09-macropad/
[13]: /s/inc/img/mp-2-after.png
[14]: /s/inc/img/mp-2-before.png
[15]: /s/inc/img/mp-combo.png

---

License:
All the text on this website is free as in freedom unless stated otherwise.
This means you can use it in any way you want, you can copy it, change it
the way you like and republish it, as long as you release the (modified)
content under the same license to give others the same freedoms you've got
and place my name and a link to this site with the article as source.

This site uses Google Analytics for statistics and Google Adwords for
advertisements. You are tracked and Google knows everything about you.
Use an adblocker like ublock-origin if you don't want it.

All the code on this website is licensed under the GNU GPL v3 license
unless already licensed under a license which does not allows this form
of licensing or if another license is stated on that page / in that software:

   This program is free software: you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation, either version 3 of the License, or
   (at your option) any later version.

   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program.  If not, see <http://www.gnu.org/licenses/>.

Just to be clear, the information on this website is for meant for educational
purposes and you use it at your own risk. I do not take responsibility if you
screw something up. Use common sense, do not 'rm -rf /' as root for example.
If you have any questions then do not hesitate to contact me.

See https://raymii.org/s/static/About.html for details.