An interactive tool for comparing layouts of different split mechanical keyboards.
In order of number of keys:
- ErgoDox (76 - 80)
- ErgoDash (66 - 72)
- Redox (70)
- Keyboardio (64)
- Nyquist (60)
- Lily58 (58)
- Iris (54 - 56)
- Kyria (46 - 50)
- Gergo (46 - 50)
- Corne (42)
- Atreus (42)
- Elephant42 (42)
- Minidox (36)
- Gergoplex (36)
- Georgi (30)
This app is an interactive tool for comparing layouts of different split mechanical keyboards, built for the DIY ergonomic keyboard community.
Typing at your computer for multiple hours every day can lead to multiple health issues, such as Repetitive Strain Injury (RSI). Using a split keyboard design offers an ergonomic solution, but finding which keyboard is right for you can be costly and difficult. Most split keyboards come as DIY kits, making it difficult (if not impossible) to compare different keyboard layouts prior to building them. This app offers a solution to this problem.
Using the magick library, this app overlays images of different keyboard layouts of the user's choosing. The app dynamically changes the colors of each keyboard image in real time to help identify the contours of each different keyboard.
Supported features include:
- A filter for whether or not the keyboard has a number row at the top.
- A filter for the degree of stagger across the key columns.
- A filter for the maximum number of keys.
- A "print" button that downloads a PDF of the keyboard layout image that is accurate to true scale when printed on 8.5 x 11 inch paper.
This app was built using the R shiny package. Shiny apps are typically used to display data and create interactive dashboards. In contrast, while there are no analyses or plots in this app, the images shown are extremely useful for the community of ergonomic keyboard users and hobbyists. The app highlights the power of libraries like magick for image manipulation in R and the flexibility of the R ecosystem by enabling the manipulated image to be inserted into a RMarkdown document and converted into a true-to-scale PDF.