Tak, jest to możliwe przy użyciu XKB. W przeciwieństwie do xmodmap, XKB może mapować klucze dla poszczególnych urządzeń.
Uwaga: Upewnij się, że masz xkbcomp> 1.2.0
Najpierw wypisz swoje urządzenia za pomocą:
xinput list
Otrzymasz coś takiego:
⎡ Virtual core pointer id=2 [master pointer (3)]
⎜ ↳ Virtual core XTEST pointer id=4 [slave pointer (2)]
⎜ ↳ Wacom Bamboo Pen Pen stylus id=11 [slave pointer (2)]
⎜ ↳ Wacom Bamboo Pen Finger touch id=12 [slave pointer (2)]
⎜ ↳ Logitech USB-PS/2 Optical Mouse id=13 [slave pointer (2)]
⎜ ↳ Wacom Bamboo Pen Pen eraser id=14 [slave pointer (2)]
⎜ ↳ Wacom Bamboo Pen Finger pad id=15 [slave pointer (2)]
⎜ ↳ GASIA USB KB V11 id=17 [slave pointer (2)]
⎣ Virtual core keyboard id=3 [master keyboard (2)]
↳ Virtual core XTEST keyboard id=5 [slave keyboard (3)]
↳ Power Button id=6 [slave keyboard (3)]
↳ Power Button id=7 [slave keyboard (3)]
↳ G19 Gaming Keyboard id=8 [slave keyboard (3)]
↳ G19 Gaming Keyboard id=9 [slave keyboard (3)]
↳ Logitech G19 Gaming Keyboard id=10 [slave keyboard (3)]
↳ GASIA USB KB V11 id=16 [slave keyboard (3)]
Zidentyfikuj ciąg urządzenia i edytuj poniższy skrypt powłoki, zmieniając linię sed na taką, która pasuje do nazwy twojego urządzenia. Następnie zmień klucze, które musisz ponownie przypisać.
Przykład: Załaduj xev
i naciśnij klawisz, który chcesz ponownie przypisać. Załóżmy, że dowiadujesz się, że jest to kod 84. Wyszukaj 84 w https://gist.github.com/zoqaeski/3880640 . Jest tam kluczowa nazwa <KP5>
. Następnie wyszukaj klucz, który chcesz zastąpić (w tym samym linku, dalej poniżej ) i skopiuj to, co jest w nawiasach. Powtórz proces dla wszystkich wymaganych kluczy.
remote_id=$(
xinput list |
sed -n 's/.*GASIA.*id=\([0-9]*\).*keyboard.*/\1/p'
)
[ "$remote_id" ] || exit
# remap the following keys, only for my custom vintage atari joystick connected
# through an old USB keyboard:
#
# keypad 5 -> keypad 6
# . -> keypad 2
# [ -> keypad 8
# left shift -> left control
mkdir -p /tmp/xkb/symbols
# This is a name for the file, it could be anything you
# want. For us, we'll name it "custom". This is important
# later.
#
# The KP_* come from /usr/include/X11/keysymdef.h
# Also note the name, "remote" is there in the stanza
# definition.
cat >/tmp/xkb/symbols/custom <<\EOF
xkb_symbols "remote" {
key <KP5> { [ KP_Right, KP_6, U2192, U21D2 ] };
key <I129> { [ KP_Down, KP_2, U2193, U21D3 ] };
key <AD12> { [ KP_Up, KP_8, U2191, U21D1 ] };
key <LFSH> { [ Control_L ] };
};
EOF
# (1) We list our current definition
# (2) Modify it to have a keyboard mapping using the name
# we used above, in this case it's the "remote" definition
# described in the file named "custom" which we specify in
# this world as "custom(remote)".
# (3) Now we take that as input back into our definition of the
# keyboard. This includes the file we just made, read in last,
# so as to override any prior definitions. Importantly we
# need to include the directory of the place we placed the file
# to be considered when reading things in.
#
# Also notice that we aren't including exactly the
# directory we specified above. In this case, it will be looking
# for a directory structure similar to /usr/share/X11/xkb
#
# What we provided was a "symbols" file. That's why above we put
# the file into a "symbols" directory, which is not being included
# below.
setxkbmap -device $remote_id -print \
| sed 's/\(xkb_symbols.*\)"/\1+custom(remote)"/' \
| xkbcomp -I/tmp/xkb -i $remote_id -synch - $DISPLAY 2>/dev/null
Następnie zdobądź go (możesz dodać go do swojego .xinitrc). Wszystko gotowe! Teraz naciśnięcie klawiszy powinno wygenerować pożądane wyjście, tylko dla określonego urządzenia.
Edycja : Ostatnio zauważyłem, że z jakiegoś powodu nowa konfiguracja nie jest stosowana natychmiast. Najpierw musisz nacisnąć klawisz na drugiej klawiaturze, a następnie przetestować skonfigurowane klawisze na zmodyfikowanej klawiaturze. Nie wiem, dlaczego tak się dzieje, może jakiś bufor.