mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-19 00:20:09 +00:00
[broadway] Send event timestamps from client
This commit is contained in:
parent
2e8f21cb1b
commit
65d4edbd5b
@ -298,19 +298,19 @@ function handleLoad(event)
|
|||||||
|
|
||||||
function on_mouse_move (ev) {
|
function on_mouse_move (ev) {
|
||||||
if (input_socket != null) {
|
if (input_socket != null) {
|
||||||
input_socket.send("m" + ev.pageX + "," + ev.pageY);
|
input_socket.send("m" + ev.pageX + "," + ev.pageY + "," + ev.timeStamp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function on_mouse_down (ev) {
|
function on_mouse_down (ev) {
|
||||||
if (input_socket != null) {
|
if (input_socket != null) {
|
||||||
input_socket.send("b" + ev.pageX + "," + ev.pageY + "," + ev.button);
|
input_socket.send("b" + ev.pageX + "," + ev.pageY + "," + ev.button + "," + ev.timeStamp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function on_mouse_up (ev) {
|
function on_mouse_up (ev) {
|
||||||
if (input_socket != null) {
|
if (input_socket != null) {
|
||||||
input_socket.send("B" + ev.pageX + "," + ev.pageY + "," + ev.button);
|
input_socket.send("B" + ev.pageX + "," + ev.pageY + "," + ev.button + "," + ev.timeStamp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -181,6 +181,7 @@ got_input (GInputStream *stream,
|
|||||||
gsize len;
|
gsize len;
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
int x, y, button;
|
int x, y, button;
|
||||||
|
guint64 time;
|
||||||
GdkEvent *event = NULL;
|
GdkEvent *event = NULL;
|
||||||
char cmd;
|
char cmd;
|
||||||
GList *node;
|
GList *node;
|
||||||
@ -205,6 +206,8 @@ got_input (GInputStream *stream,
|
|||||||
x = strtol(p, &p, 10);
|
x = strtol(p, &p, 10);
|
||||||
p++; /* Skip , */
|
p++; /* Skip , */
|
||||||
y = strtol(p, &p, 10);
|
y = strtol(p, &p, 10);
|
||||||
|
p++; /* Skip , */
|
||||||
|
time = strtol(p, &p, 10);
|
||||||
|
|
||||||
window = _gdk_window_find_child_at (root, x, y);
|
window = _gdk_window_find_child_at (root, x, y);
|
||||||
|
|
||||||
@ -242,7 +245,7 @@ got_input (GInputStream *stream,
|
|||||||
{
|
{
|
||||||
event = gdk_event_new (GDK_ENTER_NOTIFY);
|
event = gdk_event_new (GDK_ENTER_NOTIFY);
|
||||||
event->crossing.window = g_object_ref (window);
|
event->crossing.window = g_object_ref (window);
|
||||||
event->crossing.time = g_get_monotonic_time () / 1000;
|
event->crossing.time = time;
|
||||||
event->crossing.x = x - GDK_WINDOW_OBJECT (window)->x;
|
event->crossing.x = x - GDK_WINDOW_OBJECT (window)->x;
|
||||||
event->crossing.y = y - GDK_WINDOW_OBJECT (window)->y;
|
event->crossing.y = y - GDK_WINDOW_OBJECT (window)->y;
|
||||||
event->crossing.x_root = x;
|
event->crossing.x_root = x;
|
||||||
@ -269,7 +272,7 @@ got_input (GInputStream *stream,
|
|||||||
{
|
{
|
||||||
event = gdk_event_new (GDK_MOTION_NOTIFY);
|
event = gdk_event_new (GDK_MOTION_NOTIFY);
|
||||||
event->motion.window = g_object_ref (window);
|
event->motion.window = g_object_ref (window);
|
||||||
event->motion.time = g_get_monotonic_time () / 1000;
|
event->motion.time = time;
|
||||||
event->motion.x = x - GDK_WINDOW_OBJECT (window)->x;
|
event->motion.x = x - GDK_WINDOW_OBJECT (window)->x;
|
||||||
event->motion.y = y - GDK_WINDOW_OBJECT (window)->y;
|
event->motion.y = y - GDK_WINDOW_OBJECT (window)->y;
|
||||||
event->motion.x_root = x;
|
event->motion.x_root = x;
|
||||||
@ -288,6 +291,8 @@ got_input (GInputStream *stream,
|
|||||||
y = strtol(p, &p, 10);
|
y = strtol(p, &p, 10);
|
||||||
p++; /* Skip , */
|
p++; /* Skip , */
|
||||||
button = strtol(p, &p, 10);
|
button = strtol(p, &p, 10);
|
||||||
|
p++; /* Skip , */
|
||||||
|
time = strtol(p, &p, 10);
|
||||||
|
|
||||||
window = _gdk_window_find_child_at (root, x, y);
|
window = _gdk_window_find_child_at (root, x, y);
|
||||||
|
|
||||||
@ -295,7 +300,7 @@ got_input (GInputStream *stream,
|
|||||||
{
|
{
|
||||||
event = gdk_event_new (cmd == 'b' ? GDK_BUTTON_PRESS : GDK_BUTTON_RELEASE);
|
event = gdk_event_new (cmd == 'b' ? GDK_BUTTON_PRESS : GDK_BUTTON_RELEASE);
|
||||||
event->button.window = g_object_ref (window);
|
event->button.window = g_object_ref (window);
|
||||||
event->button.time = g_get_monotonic_time () / 1000;
|
event->button.time = time;
|
||||||
event->button.x = x - GDK_WINDOW_OBJECT (window)->x;
|
event->button.x = x - GDK_WINDOW_OBJECT (window)->x;
|
||||||
event->button.y = y - GDK_WINDOW_OBJECT (window)->y;
|
event->button.y = y - GDK_WINDOW_OBJECT (window)->y;
|
||||||
event->button.x_root = x;
|
event->button.x_root = x;
|
||||||
|
Loading…
Reference in New Issue
Block a user