From 2acd10d7b0b1be2cbb6eefb0a6254cd3caad3ffa Mon Sep 17 00:00:00 2001 From: Maxim Zakharov Date: Wed, 21 Sep 2022 15:20:03 +1000 Subject: [PATCH] gdk/broadway: correct gdk_broadway_device_query_state() to return pointer coordinates relative to the upper left corner of surface --- gdk/broadway/gdkdevice-broadway.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/gdk/broadway/gdkdevice-broadway.c b/gdk/broadway/gdkdevice-broadway.c index 37be4fa1ef..da4bc256de 100644 --- a/gdk/broadway/gdkdevice-broadway.c +++ b/gdk/broadway/gdkdevice-broadway.c @@ -84,6 +84,7 @@ gdk_broadway_device_query_state (GdkDevice *device, gint32 device_root_x, device_root_y; guint32 mouse_toplevel_id; guint32 mask32; + int origin_x, origin_y; if (gdk_device_get_source (device) != GDK_SOURCE_MOUSE) return; @@ -97,10 +98,12 @@ gdk_broadway_device_query_state (GdkDevice *device, &device_root_y, &mask32); + gdk_surface_get_origin (surface, &origin_x, &origin_y); + if (win_x) - *win_x = device_root_x; + *win_x = device_root_x - origin_x; if (win_y) - *win_y = device_root_y; + *win_y = device_root_y - origin_y; if (mask) *mask = mask32; }