mirror of
https://github.com/NickHu/sway
synced 2025-01-01 06:20:19 +01:00
Add libinput send_events config for touch
This commit is contained in:
parent
5d19906556
commit
8e147b3f1d
1 changed files with 26 additions and 0 deletions
|
@ -116,6 +116,28 @@ static void input_manager_libinput_config_keyboard(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void input_manager_libinput_config_touch(
|
||||||
|
struct sway_input_device *input_device) {
|
||||||
|
struct wlr_input_device *wlr_device = input_device->wlr_device;
|
||||||
|
struct input_config *ic = input_device_get_config(input_device);
|
||||||
|
struct libinput_device *libinput_device;
|
||||||
|
|
||||||
|
if (!ic || !wlr_input_device_is_libinput(wlr_device)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
libinput_device = wlr_libinput_get_device_handle(wlr_device);
|
||||||
|
wlr_log(WLR_DEBUG, "input_manager_libinput_config_touch(%s)",
|
||||||
|
ic->identifier);
|
||||||
|
|
||||||
|
if (ic->send_events != INT_MIN) {
|
||||||
|
wlr_log(WLR_DEBUG, "libinput_config_touch(%s) send_events_set_mode(%d)",
|
||||||
|
ic->identifier, ic->send_events);
|
||||||
|
libinput_device_config_send_events_set_mode(libinput_device,
|
||||||
|
ic->send_events);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void input_manager_libinput_config_pointer(
|
static void input_manager_libinput_config_pointer(
|
||||||
struct sway_input_device *input_device) {
|
struct sway_input_device *input_device) {
|
||||||
struct wlr_input_device *wlr_device = input_device->wlr_device;
|
struct wlr_input_device *wlr_device = input_device->wlr_device;
|
||||||
|
@ -267,6 +289,8 @@ static void handle_new_input(struct wl_listener *listener, void *data) {
|
||||||
input_manager_libinput_config_pointer(input_device);
|
input_manager_libinput_config_pointer(input_device);
|
||||||
} else if (input_device->wlr_device->type == WLR_INPUT_DEVICE_KEYBOARD) {
|
} else if (input_device->wlr_device->type == WLR_INPUT_DEVICE_KEYBOARD) {
|
||||||
input_manager_libinput_config_keyboard(input_device);
|
input_manager_libinput_config_keyboard(input_device);
|
||||||
|
} else if (input_device->wlr_device->type == WLR_INPUT_DEVICE_TOUCH) {
|
||||||
|
input_manager_libinput_config_touch(input_device);
|
||||||
}
|
}
|
||||||
|
|
||||||
wl_signal_add(&device->events.destroy, &input_device->device_destroy);
|
wl_signal_add(&device->events.destroy, &input_device->device_destroy);
|
||||||
|
@ -430,6 +454,8 @@ void input_manager_apply_input_config(struct sway_input_manager *input,
|
||||||
input_manager_libinput_config_pointer(input_device);
|
input_manager_libinput_config_pointer(input_device);
|
||||||
} else if (input_device->wlr_device->type == WLR_INPUT_DEVICE_KEYBOARD) {
|
} else if (input_device->wlr_device->type == WLR_INPUT_DEVICE_KEYBOARD) {
|
||||||
input_manager_libinput_config_keyboard(input_device);
|
input_manager_libinput_config_keyboard(input_device);
|
||||||
|
} else if (input_device->wlr_device->type == WLR_INPUT_DEVICE_TOUCH) {
|
||||||
|
input_manager_libinput_config_touch(input_device);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct sway_seat *seat = NULL;
|
struct sway_seat *seat = NULL;
|
||||||
|
|
Loading…
Reference in a new issue