2018-05-11 21:25:05 -04:00
|
|
|
sway-input(5)
|
|
|
|
|
|
|
|
# NAME
|
|
|
|
|
2016-01-22 19:15:03 +01:00
|
|
|
sway-input - input configuration file and commands
|
2016-01-17 02:53:37 -08:00
|
|
|
|
2018-05-11 21:25:05 -04:00
|
|
|
# DESCRIPTION
|
2016-01-17 02:53:37 -08:00
|
|
|
|
2017-12-16 08:19:33 -05:00
|
|
|
Sway allows for configuration of devices within the sway configuration file.
|
2019-01-27 11:27:34 -05:00
|
|
|
To obtain a list of available device identifiers, run *swaymsg -t get_inputs*.
|
2019-02-16 17:42:56 -05:00
|
|
|
Settings can also be applied to all input devices by using the wildcard, _\*_,
|
2019-03-25 22:05:49 -04:00
|
|
|
in place of _\<identifier\>_ in the commands below. In addition, the settings
|
|
|
|
can be applied to a type of device, by using _type:\<input_type\>_ in place
|
|
|
|
of _\<identifier\>_.
|
2019-02-16 17:42:56 -05:00
|
|
|
|
|
|
|
Tip: If the configuration settings do not appear to be taking effect, you could
|
|
|
|
try using _\*_ instead of _\<identifier\>_. If it works with the wildcard, try
|
|
|
|
using a different identifier from *swaymsg -t get_inputs* until you find the
|
|
|
|
correct input device.
|
2016-01-17 02:53:37 -08:00
|
|
|
|
2019-03-25 22:05:49 -04:00
|
|
|
Current available input types are:
|
|
|
|
|
|
|
|
- touchpad
|
|
|
|
- pointer
|
|
|
|
- keyboard
|
|
|
|
- touch
|
|
|
|
- tablet_tool
|
|
|
|
- tablet_pad
|
|
|
|
- switch
|
|
|
|
|
|
|
|
Note: The type configurations are applied as the devices appear and get applied
|
|
|
|
on top of the existing device configurations.
|
|
|
|
|
2018-05-11 21:25:05 -04:00
|
|
|
# INPUT COMMANDS
|
2017-12-16 08:19:33 -05:00
|
|
|
|
2018-05-11 21:25:05 -04:00
|
|
|
## KEYBOARD CONFIGURATION
|
2017-12-16 08:19:33 -05:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> repeat_delay <n>
|
2018-10-03 07:48:35 -04:00
|
|
|
Sets the delay before repeating a held-down key, in milliseconds.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> repeat_rate <n>
|
2018-10-03 07:48:35 -04:00
|
|
|
Sets the key repeat rate in number of keypresses per second.
|
|
|
|
|
2017-12-16 08:19:33 -05:00
|
|
|
For more information on these xkb configuration options, see
|
2018-05-11 21:25:05 -04:00
|
|
|
*xkeyboard-config*(7).
|
2017-12-16 08:19:33 -05:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> xkb_layout <layout_name>
|
2017-12-16 08:19:33 -05:00
|
|
|
Sets the layout of the keyboard like _us_ or _de_.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> xkb_model <model_name>
|
2018-05-11 21:25:05 -04:00
|
|
|
Sets the model of the keyboard. This has an influence for some extra keys
|
|
|
|
your keyboard might have.
|
2017-12-16 08:19:33 -05:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> xkb_options <options>
|
2017-12-16 08:19:33 -05:00
|
|
|
Sets extra xkb configuration options for the keyboard.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> xkb_rules <rules>
|
2017-12-16 08:19:33 -05:00
|
|
|
Sets files of rules to be used for keyboard mapping composition.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> xkb_variant <variant>
|
2017-12-16 08:19:33 -05:00
|
|
|
Sets the variant of the keyboard like _dvorak_ or _colemak_.
|
|
|
|
|
2018-07-25 17:08:47 +02:00
|
|
|
The following commands may only be used in the configuration file.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> xkb_capslock enabled|disabled
|
2018-10-03 07:48:35 -04:00
|
|
|
Initially enables or disables CapsLock on startup, the default is disabled.
|
2018-07-23 14:41:11 +02:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> xkb_numlock enabled|disabled
|
2018-10-03 07:48:35 -04:00
|
|
|
Initially enables or disables NumLock on startup, the default is disabled.
|
2018-07-23 14:41:11 +02:00
|
|
|
|
2018-05-11 21:25:05 -04:00
|
|
|
## MAPPING CONFIGURATION
|
2018-04-08 14:15:13 -04:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> map_to_output <identifier>
|
2018-04-08 14:15:13 -04:00
|
|
|
Maps inputs from this device to the specified output. Only meaningful if the
|
|
|
|
device is a pointer, touch, or drawing tablet device.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> map_to_region <WxH@X,Y>
|
2018-04-08 14:15:13 -04:00
|
|
|
Maps inputs from this device to the specified region of the global output
|
|
|
|
layout. Only meaningful if the device is a pointer, touch, or drawing tablet
|
|
|
|
device.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> map_from_region <X1xY1> <X2xY2>
|
2018-04-24 19:39:29 +01:00
|
|
|
Ignores inputs from this device that do not occur within the specified
|
|
|
|
region. Can be in millimeters (e.g. 10x20mm 20x40mm) or in terms of 0..1
|
|
|
|
(e.g. 0.5x0.5 0.7x0.7). Not all devices support millimeters. Only meaningful
|
|
|
|
if the device is not a keyboard an provides events in absolute terms (such
|
|
|
|
as a drawing tablet or touch screen - most pointers provide events relative
|
|
|
|
to the previous frame).
|
2018-04-08 14:15:13 -04:00
|
|
|
|
2018-05-11 21:25:05 -04:00
|
|
|
## LIBINPUT CONFIGURATION
|
2016-01-17 02:53:37 -08:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> accel_profile adaptive|flat
|
2016-05-01 11:02:44 +01:00
|
|
|
Sets the pointer acceleration profile for the specified input device.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> click_method none|button_areas|clickfinger
|
2016-01-17 02:53:37 -08:00
|
|
|
Changes the click method for the specified device.
|
|
|
|
|
2018-09-29 11:49:41 +02:00
|
|
|
*input* <identifier> drag enabled|disabled
|
|
|
|
Enables or disables tap-and-drag for specified input device.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> drag_lock enabled|disabled
|
2016-01-17 02:53:37 -08:00
|
|
|
Enables or disables drag lock for specified input device.
|
|
|
|
|
2018-05-11 21:25:05 -04:00
|
|
|
*input* <identifier> dwt enabled|disabled
|
2016-01-17 02:53:37 -08:00
|
|
|
Enables or disables disable-while-typing for the specified input device.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> events enabled|disabled|disabled_on_external_mouse|toggle [<toggle-modes>]
|
|
|
|
Enables or disables send_events for specified input device. Disabling
|
|
|
|
send_events disables the input device.
|
2019-01-21 02:13:01 -05:00
|
|
|
|
|
|
|
The _toggle_ option cannot be used in the config. If no toggle modes are
|
|
|
|
listed, all supported modes for the device will be toggled through in the
|
2019-01-27 11:27:34 -05:00
|
|
|
order: enabled, disabled_on_external_mouse, disabled, (loop back). If
|
2019-01-21 02:13:01 -05:00
|
|
|
toggle modes are listed, they will be cycled through, defaulting to the
|
|
|
|
first mode listed if the current mode is not in the list. They will also
|
|
|
|
not be checked to see if they are supported for the device and may fail.
|
2016-01-17 02:53:37 -08:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> left_handed enabled|disabled
|
2016-10-25 22:03:58 +02:00
|
|
|
Enables or disables left handed mode for specified input device.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> middle_emulation enabled|disabled
|
2016-01-17 02:53:37 -08:00
|
|
|
Enables or disables middle click emulation.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> natural_scroll enabled|disabled
|
2016-06-10 09:32:14 -04:00
|
|
|
Enables or disables natural (inverted) scrolling for the specified input
|
|
|
|
device.
|
2016-01-17 02:53:37 -08:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> pointer_accel [<-1|1>]
|
2016-01-17 02:53:37 -08:00
|
|
|
Changes the pointer acceleration for the specified input device.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> repeat_delay <milliseconds>
|
2018-04-18 23:19:23 +10:00
|
|
|
Sets the amount of time a key must be held before it starts repeating.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> repeat_rate <characters per second>
|
|
|
|
Sets the frequency of key repeats once the repeat_delay has passed.
|
2018-04-18 23:19:23 +10:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> scroll_button disable|button[1-3,8,9]|<event-code-or-name>
|
|
|
|
Sets the button used for scroll_method on_button_down. The button can
|
2019-01-10 12:45:52 -05:00
|
|
|
be given as an event name or code, which can be obtained from `libinput
|
|
|
|
debug-events`, or as a x11 mouse button (button[1-3,8,9]). If set to
|
2019-01-27 11:27:34 -05:00
|
|
|
_disable_, it disables the scroll_method on_button_down.
|
2016-01-17 02:53:37 -08:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> scroll_factor <floating point value>
|
2018-11-17 14:31:33 -05:00
|
|
|
Changes the scroll factor for the specified input device. Scroll speed will
|
|
|
|
be scaled by the given value, which must be non-negative.
|
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> scroll_method none|two_finger|edge|on_button_down
|
2018-11-17 14:31:33 -05:00
|
|
|
Changes the scroll method for the specified input device.
|
|
|
|
|
2018-05-11 21:25:05 -04:00
|
|
|
*input* <identifier> tap enabled|disabled
|
2016-01-17 02:53:37 -08:00
|
|
|
Enables or disables tap for specified input device.
|
2016-01-22 19:17:55 +01:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*input* <identifier> tap_button_map lrm|lmr
|
2018-07-14 01:01:47 -04:00
|
|
|
Specifies which button mapping to use for tapping. _lrm_ treats 1 finger as
|
|
|
|
left click, 2 fingers as right click, and 3 fingers as middle click. _lmr_
|
|
|
|
treats 1 finger as left click, 2 fingers as middle click, and 3 fingers as
|
|
|
|
right click.
|
|
|
|
|
2018-05-11 21:25:05 -04:00
|
|
|
## SEAT CONFIGURATION
|
2017-12-16 08:19:33 -05:00
|
|
|
|
2018-09-28 13:24:49 -04:00
|
|
|
Configure options for multiseat mode.
|
2017-12-16 08:19:33 -05:00
|
|
|
|
2018-05-11 21:25:05 -04:00
|
|
|
A *seat* is a collection of input devices that act independently of each other.
|
2017-12-16 08:19:33 -05:00
|
|
|
Seats are identified by name and the default seat is _seat0_ if no seats are
|
2019-02-02 22:02:28 -05:00
|
|
|
configured. While sway is running, _-_ (hyphen) can be used as an alias for the
|
|
|
|
current seat. Each seat has an independent keyboard focus and a separate cursor
|
|
|
|
that is controlled by the pointer devices of the seat. This is useful for
|
|
|
|
multiple people using the desktop at the same time with their own devices (each
|
2019-02-16 17:42:56 -05:00
|
|
|
sitting in their own "seat"). The wildcard character, _\*_, can also be used in
|
|
|
|
place of _\<identifier\>_ to change settings for all seats.
|
|
|
|
|
|
|
|
Tip: If the configuration settings do not appear to be taking effect, you could
|
|
|
|
try using _\*_ instead of _\<identifier\>_. If it works with the wildcard, try
|
|
|
|
using a different identifier from *swaymsg -t get_seats* until you find the
|
|
|
|
correct seat.
|
2017-12-16 08:19:33 -05:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*seat* <name> attach <input_identifier>
|
2018-05-11 21:25:05 -04:00
|
|
|
Attach an input device to this seat by its input identifier. A special
|
|
|
|
value of "\*" will attach all devices to the seat.
|
2017-12-16 08:19:33 -05:00
|
|
|
|
2019-01-10 11:47:34 -05:00
|
|
|
*seat* <seat> cursor move|set <x> <y>
|
|
|
|
Move specified seat's cursor relative to current position or wrap to
|
|
|
|
absolute coordinates (with respect to the global coordinate space).
|
|
|
|
Specifying either value as 0 will not update that coordinate.
|
|
|
|
|
|
|
|
*seat* <seat> cursor press|release button[1-9]|<event-name-or-code>
|
|
|
|
Simulate pressing (or releasing) the specified mouse button on the
|
|
|
|
specified seat. The button can either be provided as a button event name or
|
|
|
|
event code, which can be obtained from `libinput debug-events`, or as an x11
|
|
|
|
mouse button (button[1-9]). If using button[4-7], which map to axes, an axis
|
|
|
|
event will be simulated, however _press_ and _release_ will be ignored and
|
|
|
|
both will occur.
|
|
|
|
|
2018-05-11 21:25:05 -04:00
|
|
|
*seat* <name> fallback true|false
|
|
|
|
Set this seat as the fallback seat. A fallback seat will attach any device
|
|
|
|
not explicitly attached to another seat (similar to a "default" seat).
|
2017-12-19 04:52:03 -05:00
|
|
|
|
2019-01-27 11:27:34 -05:00
|
|
|
*seat* <name> hide_cursor <timeout>
|
2018-12-27 00:32:15 -05:00
|
|
|
Hides the cursor image after the specified _timeout_ (in milliseconds)
|
|
|
|
has elapsed with no activity on that cursor. A timeout of 0 (default)
|
|
|
|
disables hiding the cursor. The minimal timeout is 100 and any value less
|
|
|
|
than that (aside from 0), will be increased to 100.
|
|
|
|
|
2019-01-31 22:58:52 -05:00
|
|
|
*seat* <name> pointer_constraint enable|disable|escape
|
|
|
|
Enables or disables the ability for clients to capture the cursor (enabled
|
|
|
|
by default) for the seat. This is primarily useful for video games. The
|
|
|
|
"escape" command can be used at runtime to escape from a captured client.
|
|
|
|
|
2018-05-11 21:25:05 -04:00
|
|
|
# SEE ALSO
|
2016-01-22 19:17:55 +01:00
|
|
|
|
2019-04-13 01:39:14 +07:00
|
|
|
*sway*(5) *sway-output*(5) *xkeyboard-config*(7)
|