mirror of
https://github.com/hyprwm/wlroots-hyprland.git
synced 2025-01-25 16:09:49 +01:00
rootston: handle request_set_cursor
This commit is contained in:
parent
78d3582b70
commit
65d57920e5
3 changed files with 29 additions and 1 deletions
|
@ -107,6 +107,8 @@ struct roots_input {
|
||||||
struct wl_listener cursor_tool_tip;
|
struct wl_listener cursor_tool_tip;
|
||||||
|
|
||||||
struct wl_listener pointer_grab_end;
|
struct wl_listener pointer_grab_end;
|
||||||
|
|
||||||
|
struct wl_listener request_set_cursor;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct roots_input *input_create(struct roots_server *server,
|
struct roots_input *input_create(struct roots_server *server,
|
||||||
|
|
|
@ -274,6 +274,24 @@ static void handle_pointer_grab_end(struct wl_listener *listener, void *data) {
|
||||||
cursor_update_position(input, 0);
|
cursor_update_position(input, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void handle_request_set_cursor(struct wl_listener *listener,
|
||||||
|
void *data) {
|
||||||
|
struct roots_input *input = wl_container_of(listener, input,
|
||||||
|
request_set_cursor);
|
||||||
|
//struct wlr_seat_pointer_request_set_cursor_event *event = data;
|
||||||
|
|
||||||
|
struct wlr_xcursor_image *image = input->xcursor->images[0];
|
||||||
|
struct roots_output *output;
|
||||||
|
wl_list_for_each(output, &input->server->desktop->outputs, link) {
|
||||||
|
if (!wlr_output_set_cursor(output->wlr_output, image->buffer,
|
||||||
|
image->width, image->width, image->height,
|
||||||
|
image->hotspot_x, image->hotspot_y)) {
|
||||||
|
wlr_log(L_DEBUG, "Failed to set hardware cursor");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void cursor_initialize(struct roots_input *input) {
|
void cursor_initialize(struct roots_input *input) {
|
||||||
struct wlr_cursor *cursor = input->cursor;
|
struct wlr_cursor *cursor = input->cursor;
|
||||||
|
|
||||||
|
@ -304,6 +322,11 @@ void cursor_initialize(struct roots_input *input) {
|
||||||
|
|
||||||
wl_signal_add(&input->wl_seat->events.pointer_grab_end, &input->pointer_grab_end);
|
wl_signal_add(&input->wl_seat->events.pointer_grab_end, &input->pointer_grab_end);
|
||||||
input->pointer_grab_end.notify = handle_pointer_grab_end;
|
input->pointer_grab_end.notify = handle_pointer_grab_end;
|
||||||
|
|
||||||
|
wl_list_init(&input->request_set_cursor.link);
|
||||||
|
wl_signal_add(&input->wl_seat->events.request_set_cursor,
|
||||||
|
&input->request_set_cursor);
|
||||||
|
input->request_set_cursor.notify = handle_request_set_cursor;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void reset_device_mappings(struct roots_config *config,
|
static void reset_device_mappings(struct roots_config *config,
|
||||||
|
|
|
@ -24,7 +24,10 @@ static void wl_pointer_set_cursor(struct wl_client *client,
|
||||||
struct wl_resource *surface_resource,
|
struct wl_resource *surface_resource,
|
||||||
int32_t hotspot_x, int32_t hotspot_y) {
|
int32_t hotspot_x, int32_t hotspot_y) {
|
||||||
struct wlr_seat_handle *handle = wl_resource_get_user_data(resource);
|
struct wlr_seat_handle *handle = wl_resource_get_user_data(resource);
|
||||||
struct wlr_surface *surface = wl_resource_get_user_data(surface_resource);
|
struct wlr_surface *surface = NULL;
|
||||||
|
if (surface_resource != NULL) {
|
||||||
|
surface = wl_resource_get_user_data(surface_resource);
|
||||||
|
}
|
||||||
|
|
||||||
struct wlr_seat_pointer_request_set_cursor_event *event =
|
struct wlr_seat_pointer_request_set_cursor_event *event =
|
||||||
calloc(1, sizeof(struct wlr_seat_pointer_request_set_cursor_event));
|
calloc(1, sizeof(struct wlr_seat_pointer_request_set_cursor_event));
|
||||||
|
|
Loading…
Reference in a new issue