The easiest and the most natural way how to specify a keyboard mapping is
to use rules
component. As its name suggests it describes a number of general
rules how to combine all bits and pieces into a valid and useful keyboard
mapping. All you need to do is to select a suitable rules file and then to
feed it with a few parameters that will adjust the keyboard behaviour to
fulfill your needs.
The parameters are:
XkbRules
- files of rules to be used for keyboard mapping
compositionXkbModel
- name of model of your keyboard typeXkbLayout
- layout(s) you intend to useXkbVariant
- variant(s) of layout you intend to useXkbOptions
- extra xkb configuration optionsThe proper rules file depends on your vendor. In reality, the commonest
file of rules is xorg
. For each rules file there is a description
file named <vendor-rules>.lst
, for instance xorg.lst
which is located in xkb configuration subdirectory rules
(for example
/etc/X11/xkb/rules
).
Let's say you want to configure a PC style America keyboard with 104
keys as described in xorg.lst
. It can be done by simply writing
several lines from below to you xorg.conf configuration file (previously known
as /etc/X11/XF86Config-4
or /etc/X11/XF86Config
):
Section "InputDevice"
Identifier "Keyboard1"
Driver "Keyboard"
Option "XkbModel" "pc104"
Option "XkbLayout" "us"
Option "XKbOptions" ""
EndSection
The values of parameters XkbModel
and XkbLayout
are really
not surprising. The parameters XkbOptions
has been explicitly set to
empty set of parameters. The parameter XkbVariant
has been left out.
That means the default variant named basic
is loaded.
Of course, this can be also done at runtime using utility setxkbmap. Shell command loading the same keyboard mapping would look like:
setxkbmap -rules xorg -model pc104 -layout us -option ""
The configuration and the shell command would be very analogical
for most other layouts (internationalized mappings).
You can use multi-layouts xkb configuration. What does it mean? Basically it allows to load up to four different keyboard layouts at a time. Each such layout would reside in its own group. The groups (unlike complete keyboard remapping) can be switched very fast from one to another by a combination of keys.
Let's say you want to configure your new Logitech cordless desktop
keyboard, you intend to use three different layouts at the same
time - us, czech and german (in this order), and that you are used
to Alt-Shift
combination for switching among them.
Then the configuration snippet could look like this:
Section "InputDevice"
Identifier "Keyboard1"
Driver "Keyboard"
Option "XkbModel" "logicordless"
Option "XkbLayout" "us,cz,de"
Option "XKbOptions" "grp:alt_shift_toggle"
EndSection
Of course, this can be also done at runtime using utility setxkbmap.
Shell command loading the same keyboard mapping would look like:
setxkbmap -rules xorg -model logicordless -layout "us,cz,de" \
-option "grp:alt_shift_toggle"
Okay, let's say you are more demanding. You do like the example above but you want it to change a bit. Let's imagine you want the czech keyboard mapping to use another variant but basic. The configuration snippet then changes into:
Section "InputDevice"
Identifier "Keyboard1"
Driver "Keyboard"
Option "XkbModel" "logicordless"
Option "XkbLayout" "us,cz,de"
Option "XkbVariant" ",bksl,"
Option "XKbOptions" "grp:alt_shift_toggle"
EndSection
That's seems tricky but it is not. The logic for settings of variants
is the same as for layouts, that means the first and the third variant
settings are left out (set to basic
), the second is set to
bksl
(a special variant with an enhanced definition of the backslash
key).
Analogically, the loading runtime will change to:
setxkmap -rules xorg -model logicordless -layout "us,cz,de" \
-variant ",bksl," -option "grp:alt_shift_toggle"
See rules/*.lst files.