[broadway] Send event timestamps from client

This commit is contained in:
Alexander Larsson 2010-11-20 22:11:54 +01:00
parent 2e8f21cb1b
commit 65d4edbd5b
2 changed files with 11 additions and 6 deletions

View File

@ -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);
} }
} }

View File

@ -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;