2020-12-19 15:09:24 +00:00
# Usage
To open the UI to modify the mappings, look into your applications menu
2020-12-24 00:26:34 +00:00
and search for 'Key Mapper'. You should be prompted for your sudo password
as special permissions are needed to read events from `/dev/input/` files.
2021-03-21 18:15:20 +00:00
You can also start it via `key-mapper-gtk` .
2020-12-19 15:09:24 +00:00
2020-12-26 16:09:52 +00:00
< p align = "center" >
< img src = "usage_1.png" / >
< img src = "usage_2.png" / >
< / p >
Hitting a key on the device that is selected in the large dropdown on the top
should display the key on the bottom of the window, and write it into the selected
row (as shown in the screenshots).
2021-03-21 13:42:35 +00:00
Changes are saved automatically. Afterwards press the "Apply" button.
2020-12-26 16:09:52 +00:00
2020-12-26 16:16:17 +00:00
To change the mapping, you need to use the "Restore Defaults" button, so that
2020-12-19 15:49:07 +00:00
the application can read the original keycode. It would otherwise be
invisible since the daemon maps it independently of the GUI.
2020-12-26 16:09:52 +00:00
## Troubleshooting
2020-12-19 15:49:07 +00:00
2021-03-21 18:15:20 +00:00
If stuff doesn't work, check the output of `key-mapper-gtk -d` and feel free
2020-12-25 14:19:01 +00:00
to [open up an issue here ](https://github.com/sezanzeb/key-mapper/issues/new ).
Make sure to not post any debug logs that were generated while you entered
private information with your device. Debug logs are quite verbose.
2020-12-19 15:09:24 +00:00
2021-02-07 14:00:36 +00:00
If key-mapper or your presets prevents your input device from working
2021-03-21 18:15:20 +00:00
at all due to autoload, please try to unplug and plug it in twice.
No injection should be running anymore.
2021-02-07 14:00:36 +00:00
2021-01-01 02:46:38 +00:00
## Combinations
Select the key in your row (`click here`) and hold a few buttons down.
Releasing them will make your text cursor jump into the mapping column
to type in what you want to map it to.
Combinations involving Ctrl might not work, I think the desktop environment
grabs them or something. Combinations with Shift might not work the way
you would expect. If it outputs the keycode for a, you are going to get an
'A', because X11 still sees the enabled shift button.
This happens, because all key-mapper does is either forwarding or mapping
your keycodes (which is easier said than done), and X11/Wayland has to decide
what to do with it. And it decides, that if shift is pressed down, it will
capitalize your stuff.
2021-04-02 17:54:33 +00:00
A better option for a key combination would be `KP1 + a` instead of
2021-01-01 02:46:38 +00:00
`LEFTSHIFT + a` , because there won't be any side effect. You can disable
2021-04-02 17:54:33 +00:00
`KP1` by mapping it to `disable` , so you won't trigger writing a "1" into
2021-01-01 02:46:38 +00:00
your focused application.
< p align = "center" >
< img src = "combination.png" / >
< / p >
2021-02-12 20:43:40 +00:00
## Writing Combinations
2021-04-02 11:42:42 +00:00
You can write `Control_L + a` as mapping, which will inject those two
2021-02-12 20:43:40 +00:00
keycodes into your system on a single key press. An arbitrary number of
names can be chained using ` + ` .
< p align = "center" >
< img src = "plus.png" / >
< / p >
2020-12-19 15:09:24 +00:00
## Macros
2021-04-25 17:28:48 +00:00
See [readme/macros.md ](macros.md )
2020-12-19 15:09:24 +00:00
2021-03-17 20:08:15 +00:00
## UI Shortcuts
2021-04-02 13:08:36 +00:00
- `ctrl` + `del` stops the injection (only works while the gui is in focus)
2021-03-17 20:08:15 +00:00
- `ctrl` + `q` closes the application
2021-04-02 13:08:36 +00:00
- `ctrl` + `r` refreshes the device list
2021-03-17 20:08:15 +00:00
2020-12-19 15:09:24 +00:00
## Key Names
Check the autocompletion of the GUI for possible values. You can also
2021-04-23 09:51:21 +00:00
obtain a complete list of possiblities using `key-mapper-control --symbol-names` .
2020-12-19 15:09:24 +00:00
Examples:
- Alphanumeric `a` to `z` and `0` to `9`
- Modifiers `Alt_L` `Control_L` `Control_R` `Shift_L` `Shift_R`
- Mouse buttons `BTN_LEFT` `BTN_RIGHT` `BTN_MIDDLE` `BTN_SIDE` ...
- Multimedia keys `KEY_NEXTSONG` `KEY_PLAYPAUSE` ...
## Gamepads
Joystick movements will be translated to mouse movements, while the second
2020-12-25 14:19:01 +00:00
joystick acts as a mouse wheel. You can swap this in the user interface.
All buttons, triggers and D-Pads can be mapped to keycodes and macros.
2020-12-19 15:09:24 +00:00
The D-Pad can be mapped to W, A, S, D for example, to run around in games,
2020-12-25 14:19:01 +00:00
while the joystick turns the view (depending on the game).
2020-12-19 15:09:24 +00:00
Tested with the XBOX 360 Gamepad. On Ubuntu, gamepads worked better in
Wayland than with X11 for me.
2020-12-19 20:50:27 +00:00
2021-02-07 14:00:36 +00:00
< br / >
< br / >
< br / >
< br / >
< br / >
< br / >
# Advanced
2021-04-23 09:51:21 +00:00
## How to use unavailable symbols
2021-04-03 21:50:07 +00:00
For example Japanese letters. Only works in X11.
```
xmodmap -pke > keyboard_layout
mousepad keyboard_layout &
```
Find a code that is not mapped to anything, for example `keycode 93 = ` ,
and map it like `keycode 93 = kana_YA` . See [this gist ](https://gist.github.com/sezanzeb/e29bae637b8a799ccf2490b8537487df )
for available symbols.
```
xmodmap keyboard_layout
key-mapper-gtk
```
2021-04-23 09:51:21 +00:00
"kana_YA" should be in the dropdown of available symbols now. Map it
2021-04-03 21:50:07 +00:00
to a key and press apply. Now run
```
xmodmap keyboard_layout
```
again for the injection to use that xmodmap as well. It should be possible
to write "ヤ" now when pressing the key.
2020-12-19 20:50:27 +00:00
## Configuration Files
2021-04-25 17:28:02 +00:00
If you don't have a graphical user interface, you'll need to edit the
configuration files.
The default configuration is stored at `~/.config/key-mapper/config.json` ,
which doesn't include any mappings, but rather other parameters that
are interesting for injections. The current default configuration as of 0.8.1
looks like, with an example autoload entry:
2020-12-19 20:50:27 +00:00
```json
{
2020-12-19 22:01:36 +00:00
"autoload": {
"Logitech USB Keyboard": "preset name"
},
2020-12-19 20:50:27 +00:00
"macros": {
"keystroke_sleep_ms": 10
},
"gamepad": {
"joystick": {
"non_linearity": 4,
"pointer_speed": 80,
2021-04-03 21:50:07 +00:00
"left_purpose": "none",
"right_purpose": "none",
2021-01-01 02:46:38 +00:00
"x_scroll_speed": 2,
"y_scroll_speed": 0.5
2020-12-19 20:50:27 +00:00
}
}
}
```
2020-12-24 00:26:34 +00:00
`preset name` refers to `~/.config/key-mapper/presets/device name/preset name.json` .
2020-12-25 14:00:57 +00:00
The device name can be found with `sudo key-mapper-control --list-devices` .
2020-12-19 22:01:36 +00:00
2020-12-19 20:50:27 +00:00
Anything that is relevant to presets can be overwritten in them as well.
Here is an example configuration for preset "a" for the "gamepad" device:
2020-12-24 00:26:34 +00:00
`~/.config/key-mapper/presets/gamepad/a.json`
2020-12-19 20:50:27 +00:00
```json
{
"macros": {
"keystroke_sleep_ms": 100
},
"mapping": {
2020-12-31 20:46:57 +00:00
"1,315,1+1,16,-1": "1",
2020-12-19 20:50:27 +00:00
"1,307,1": "k(2).k(3)"
}
}
```
Both need to be valid json files, otherwise the parser refuses to work. This
2020-12-31 20:46:57 +00:00
preset maps the EV_KEY down event with code 307 to a macro and sets the time
2021-04-04 10:55:44 +00:00
between injected events of macros to 100 ms. Note that a complete keystroke
consists of two events: down and up. The other mapping is a key combination,
chained using `+` .
2020-12-31 20:46:57 +00:00
2021-04-04 10:55:44 +00:00
Other than that, it inherits all configurations from
2020-12-31 20:46:57 +00:00
`~/.config/key-mapper/config.json` . If config.json is missing some stuff,
it will query the hardcoded default values.
2020-12-19 20:53:32 +00:00
2020-12-19 22:01:36 +00:00
The event codes can be read using `evtest` . Available names in the mapping
2021-04-23 09:51:21 +00:00
can be listed with `key-mapper-control --symbol-names` .
2020-12-24 00:26:34 +00:00
## CLI
2020-12-24 10:00:28 +00:00
**key-mapper-control**
2020-12-24 00:26:34 +00:00
`--command` requires the service to be running. You can start it via
`systemctl start key-mapper` or `sudo key-mapper-service` if it isn't already
running (or without sudo if your user has the appropriate permissions).
2021-02-07 14:00:36 +00:00
Examples:
2021-04-23 09:51:21 +00:00
| Description | Command |
|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| Load all configured presets for all devices | `key-mapper-control --command autoload` |
| If you are running as root user, provide information about the whereabouts of the key-mapper config | `key-mapper-control --command autoload --config-dir "~/.config/key-mapper/"` |
| List available device names for the `--device` parameter | `sudo key-mapper-control --list-devices` |
| Stop injecting | `key-mapper-control --command stop --device "Razer Razer Naga Trinity"` |
| Load `~/.config/key-mapper/presets/Razer Razer Naga Trinity/a.json` | `key-mapper-control --command start --device "Razer Razer Naga Trinity" --preset "a"` |
| Loads the configured preset for whatever device is using this /dev path | `/bin/key-mapper-control --command autoload --device /dev/input/event5` |
2020-12-24 10:00:28 +00:00
**systemctl**
2021-04-23 09:51:21 +00:00
Stopping the service will stop all ongoing injections
2020-12-24 10:00:28 +00:00
```bash
sudo systemctl stop key-mapper
sudo systemctl start key-mapper
systemctl status key-mapper
```
2020-12-25 14:19:01 +00:00
## Testing your Installation
The following commands can be used to make sure it works:
```bash
sudo key-mapper-service &
key-mapper-control --command hello
```
should print `Daemon answered with "hello"` . And
```bash
sudo key-mapper-control --list-devices
```
should print `Found "...", ...` . If anything looks wrong, feel free to [create
an issue](https://github.com/sezanzeb/key-mapper/issues/new).