mirror of
https://gitlab.freedesktop.org/wlroots/wlroots.git
synced 2026-02-07 04:06:14 -05:00
input_timestamps: add support for input-timestamps-unstable-v1 protocol
This protocol specifies a way for a client to request and receive high-resolution timestamps for input events. Touch input event are unsupported as of now.
This commit is contained in:
parent
e617da0378
commit
ab3a760874
5 changed files with 499 additions and 21 deletions
|
|
@ -10,26 +10,27 @@ install_headers(
|
|||
'wlr_fullscreen_shell_v1.h',
|
||||
'wlr_gamma_control_v1.h',
|
||||
'wlr_gtk_primary_selection.h',
|
||||
'wlr_idle_inhibit_v1.h',
|
||||
'wlr_idle.h',
|
||||
'wlr_idle_inhibit_v1.h',
|
||||
'wlr_input_device.h',
|
||||
'wlr_input_inhibitor.h',
|
||||
'wlr_input_method_v2.h',
|
||||
'wlr_input_timestamps_v1.h',
|
||||
'wlr_keyboard.h',
|
||||
'wlr_layer_shell_v1.h',
|
||||
'wlr_linux_dmabuf_v1.h',
|
||||
'wlr_list.h',
|
||||
'wlr_matrix.h',
|
||||
'wlr_output.h',
|
||||
'wlr_output_damage.h',
|
||||
'wlr_output_layout.h',
|
||||
'wlr_output_management_v1.h',
|
||||
'wlr_output.h',
|
||||
'wlr_pointer.h',
|
||||
'wlr_pointer_constraints_v1.h',
|
||||
'wlr_pointer_gestures_v1.h',
|
||||
'wlr_pointer.h',
|
||||
'wlr_presentation_time.h',
|
||||
'wlr_primary_selection_v1.h',
|
||||
'wlr_primary_selection.h',
|
||||
'wlr_primary_selection_v1.h',
|
||||
'wlr_region.h',
|
||||
'wlr_relative_pointer_v1.h',
|
||||
'wlr_screencopy_v1.h',
|
||||
|
|
@ -46,7 +47,7 @@ install_headers(
|
|||
'wlr_xcursor_manager.h',
|
||||
'wlr_xdg_decoration_v1.h',
|
||||
'wlr_xdg_output_v1.h',
|
||||
'wlr_xdg_shell_v6.h',
|
||||
'wlr_xdg_shell.h',
|
||||
'wlr_xdg_shell_v6.h',
|
||||
subdir: 'wlr/types',
|
||||
)
|
||||
|
|
|
|||
110
include/wlr/types/wlr_input_timestamps_v1.h
Normal file
110
include/wlr/types/wlr_input_timestamps_v1.h
Normal file
|
|
@ -0,0 +1,110 @@
|
|||
/*
|
||||
* This an unstable interface of wlroots. No guarantees are made regarding the
|
||||
* future consistency of this API.
|
||||
*/
|
||||
#ifndef WLR_USE_UNSTABLE
|
||||
#error "Add -DWLR_USE_UNSTABLE to enable unstable wlroots features"
|
||||
#endif
|
||||
|
||||
#ifndef WLR_TYPES_WLR_INPUT_TIMESTAMPS_V1_H
|
||||
#define WLR_TYPES_WLR_INPUT_TIMESTAMPS_V1_H
|
||||
|
||||
#include <wayland-server.h>
|
||||
|
||||
/**
|
||||
* This protocol specifies a way for a client to request and receive
|
||||
* high-resolution timestamps for input events.
|
||||
*/
|
||||
|
||||
/**
|
||||
* A global interface used for requesting high-resolution timestamps for
|
||||
* input events.
|
||||
*/
|
||||
struct wlr_input_timestamps_manager_v1 {
|
||||
struct wl_global *global;
|
||||
struct wl_list resources; // wl_resource_get_link()
|
||||
struct wl_list input_timestamps; // wlr_input_timestamps_v1::link
|
||||
|
||||
struct {
|
||||
struct wl_signal destroy;
|
||||
} events;
|
||||
|
||||
struct wl_listener display_destroy_listener;
|
||||
|
||||
void *data;
|
||||
};
|
||||
|
||||
/**
|
||||
* Enum used to specify the type of input device to provide event timestamps
|
||||
* for.
|
||||
*/
|
||||
enum wlr_input_timestamps_type {
|
||||
WLR_INPUT_TIMESTAMPS_KEYBOARD,
|
||||
WLR_INPUT_TIMESTAMPS_POINTER,
|
||||
WLR_INPUT_TIMESTAMPS_TOUCH,
|
||||
};
|
||||
|
||||
/**
|
||||
* Provides high-resolution timestamp events for a set of subscribed input
|
||||
* events. The set of subscribed input events is determined by the
|
||||
* zwp_input_timestamps_manager_v1 request used to create this object.
|
||||
*/
|
||||
struct wlr_input_timestamps_v1 {
|
||||
struct wl_resource *resource;
|
||||
struct wl_resource *input_resource;
|
||||
struct wlr_seat *seat;
|
||||
struct wl_list link; // wlr_input_timestamps_manager_v1::input_timestamps
|
||||
|
||||
enum wlr_input_timestamps_type input_timestamps_type;
|
||||
|
||||
struct {
|
||||
struct wl_signal destroy;
|
||||
} events;
|
||||
|
||||
struct wl_listener seat_destroy;
|
||||
struct wl_listener input_destroy;
|
||||
|
||||
void *data;
|
||||
};
|
||||
|
||||
/**
|
||||
* Public creator and destructor functions.
|
||||
*/
|
||||
struct wlr_input_timestamps_manager_v1 *wlr_input_timestamps_manager_v1_create(
|
||||
struct wl_display *display);
|
||||
|
||||
void wlr_input_timestamps_manager_v1_destroy(
|
||||
struct wlr_input_timestamps_manager_v1 *manager);
|
||||
|
||||
/**
|
||||
* Public functions to send timestamps for a particular set of subscribed
|
||||
* events, depending on the type of input device.
|
||||
*
|
||||
* The timestamp event is associated with the first subsequent input event
|
||||
* carrying a timestamp which belongs to the set of input events this object is
|
||||
* subscribed to.
|
||||
*
|
||||
* The timestamp provided by this event is a high-resolution version of the
|
||||
* timestamp argument of the associated input event. The provided timestamp is
|
||||
* in the same clock domain and is at least as accurate as the associated input
|
||||
* event timestamp.
|
||||
*
|
||||
* The timestamp is expressed as tv_sec_hi, tv_sec_lo, tv_nsec triples, each
|
||||
* component being an unsigned 32-bit value. Whole seconds are in tv_sec which
|
||||
* is a 64-bit value combined from tv_sec_hi and tv_sec_lo, and the additional
|
||||
* fractional part in tv_nsec as nanoseconds. Hence, for valid timestamps
|
||||
* tv_nsec must be in [0, 999999999].
|
||||
*/
|
||||
void wlr_input_timestamps_manager_v1_send_keyboard_timestamp(
|
||||
struct wlr_input_timestamps_manager_v1 *manager, struct wlr_seat *seat,
|
||||
uint64_t tv_sec, uint32_t tv_nsec);
|
||||
|
||||
void wlr_input_timestamps_manager_v1_send_pointer_timestamp(
|
||||
struct wlr_input_timestamps_manager_v1 *manager, struct wlr_seat *seat,
|
||||
uint64_t tv_sec, uint32_t tv_nsec);
|
||||
|
||||
void wlr_input_timestamps_manager_v1_send_touch_timestamp(
|
||||
struct wlr_input_timestamps_manager_v1 *manager, struct wlr_seat *seat,
|
||||
uint64_t tv_sec, uint32_t tv_nsec);
|
||||
|
||||
#endif
|
||||
Loading…
Add table
Add a link
Reference in a new issue