RaspiKey converts a bluetooth keyboard to a standard wired USB keyboard. It is particularly useful with the Apple Wireless keyboards because it translates their exotic keymap to that of a standard PC and makes them fully usable on a Windows PC or on other devices (TVs, game consoles, etc.).
RaspiKey requires a Raspberry Pi Zero W hardware board.
- RaspiKey supports any bluetooth keyboard but it currently offers multimedia key support only for the Apple Wireless (A1314) and the Apple Magic (A1644) models. Furthermore, RaspiKey can be used on any device that accepts a standard USB keyboard. This means that you can use an Apple keyboard on a PC, a smart TV or on a game console.
- It does not require a driver installation or other software. It is also completely self-powered through the USB port.
- It is secure. As it is a hardware device, there is no software driver running on your PC that can be hacked, intercepted or compromised compared to a software solution. You have full access to its source code to review it, or even build it yourself.
- It is based on a cut-down, readonly version of the official Raspbian Linux. Even though it runs an OS internally, there is no need for a shutdown process, you just unplug it when you want.
- RaspiKey supports Custom Keymaps, allowing you to customise and remap keyboard keys.
- Highly performant compile-time optimised native code; written entirely in C/C++. Thanks to that, Input latency measurements with the Apple Magic Keyboard achieved an impressive minimum input latency of 14 msec. Compared to these results, the latency impact of RaspiKey is negligible. It was virtually impossible to detect any measurable difference in minimum input latency between the wired USB setup and the wireless Bluetooth setup of that same Apple Magic Keyboard using RaspiKey.
- A plain Raspberry Pi Zero W board.
- A 2GB (or bigger if not available) micro SD card.
- Access to a modern Windows PC with a Web browser. You need this to build your new RaspiKey device and tether a Bluetooth keyboard to it for the first time.
- Download and install Etcher.
- Download the latest Raspios headless release 2020-08-20-raspios-buster-armhf-lite-headless.xz from here.
- Use Etcher to write the 2020-08-20-raspios-buster-armhf-lite-headless.xz image to the SD card.
- Download the latest RaspiKey release raspikey-setup.*.zip from here.
- Copy the raspikey-setup.*.zip (as-is) to the the SD card. The SD card should appear on Windows as a drive named boot.
- Now insert the SD card to your Raspberry Pi Zero W device and connect it to the PC using the middle micro-USB port (labelled USB in tiny white letters).
- The Pi will boot and continue its setup. This process lasts about 5-6 minutes. You will be able to tell when it's finished when the Raspberry Pi's green led goes off (it stays solid green during setup). Once that happens, unplug it from the PC's USB port.
- Your new RaspiKey device is now fully configured and ready to use.
- Connect (re-connect) your RaspiKey device to the PC using the middle micro-USB port. Attention: Please make sure that you are using a standard (data) micro USB cable and not a charging-only one, typically used by portable USB chargers, or your PC will not be abble to communicate with the RaspiKey.
- Wait for about 10 seconds for it to start and open your PC Web browser at: http://169.254.1.1
- Use the displayed configuration page to discover and connect a Bluetooth keyboard to it. Once the keyboard is connected, it will be usable on this PC directly or on anywhere else that you plug RaspiKey to. That is, you do not need to reconfigure RaspiKey to plug it in and use it elsewhere.
- The battery level indicator does not work on the Apple Magic (A1644) keyboard.
Input Key(s) | Output Key |
---|---|
LCtrl | Fn |
Fn | Left Ctrl |
⏏︎ Eject | Del |
⌘ Cmd | Alt |
⌥ Alt | Cmd |
Fn+[F1]...[F6] | [F13]...[F18] |
Fn+[F7]...[F12] | Multimedia Keys |
Fn+LCtrl | Right Ctrl |
Fn+Return | Insert |
Fn+⌫ | Del |
Fn+P | Print Screen |
Fn+S | Scroll Lock |
Fn+B | Pause/Break |
Fn+↑ | Page Up |
Fn+↓ | Page Down |
Fn+← | Home |
Fn+→ | End |
You can use the configuration page to optionally upload a custom keymap JSON file. The file has to define an array of input key filters and output keys in the following format:
[
[input-modifier-mask, input-key-scancode, output-modifier-mask, output-key-scancode],
...
]
For instance a file such as this:
[
[null, "0x35", null, "0x64"],
[null, "0x64", null, "0x35"]
]
will swap the following keys: KEY_GRAVE - 0x35 (Keyboard ` and ~) to KEY_102ND 0x64 (Keyboard Non-US \ and |)
The optional *-modifier-mask can be used to filter the Ctrl, Shift and Alt special key combinations if needed. If not used, you set it to null (as in the above example).
You can refer to this document to find out the HID scan codes of specific keys.
Examples:
-
A Keymap for the German Apple keyboard versions so that all keys work as expected is available here.
-
A Keymap for the UK and International English versions is here. This keymap swaps the ` key with the key below Esc.
RaspiKey is a free and open-source software effort. If you like it and find it useful, please consider donating