diff options
author | Matthias Clasen <mclasen@redhat.com> | 2021-03-12 14:06:33 +0000 |
---|---|---|
committer | Matthias Clasen <mclasen@redhat.com> | 2021-03-12 14:06:33 +0000 |
commit | 7f292d34bd1841df1ea214037d0549b256f315da (patch) | |
tree | a0352b34b5863ed4ccbbff139abb685e47b33b32 | |
parent | 28e33bc26c83db23ca6c626ee3e3e688c5594baa (diff) | |
parent | e941e2be7ded88728f41cdd03acd3381e45562b0 (diff) | |
download | gtk+-7f292d34bd1841df1ea214037d0549b256f315da.tar.gz |
Merge branch 'fix-3704' into 'master'
gdksurface-win32.c: Fix window menu positioning (issue #3704)
Closes #3704
See merge request GNOME/gtk!3286
-rw-r--r-- | gdk/win32/gdksurface-win32.c | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/gdk/win32/gdksurface-win32.c b/gdk/win32/gdksurface-win32.c index cd113bc4df..d600996fe2 100644 --- a/gdk/win32/gdksurface-win32.c +++ b/gdk/win32/gdksurface-win32.c @@ -4279,14 +4279,15 @@ gdk_win32_surface_is_win32 (GdkSurface *window) } static gboolean -gdk_win32_surface_show_window_menu (GdkSurface *window, - GdkEvent *event) +gdk_win32_surface_show_window_menu (GdkSurface *surface, + GdkEvent *event) { double event_x, event_y; int x, y; - GdkWin32Surface *impl = GDK_WIN32_SURFACE (window); + GdkWin32Surface *impl = GDK_WIN32_SURFACE (surface); + GdkEventType event_type = gdk_event_get_event_type (event); - switch ((int) event->event_type) + switch ((int) event_type) { case GDK_BUTTON_PRESS: case GDK_BUTTON_RELEASE: @@ -4298,10 +4299,9 @@ gdk_win32_surface_show_window_menu (GdkSurface *window, } gdk_event_get_position (event, &event_x, &event_y); - x = round (event_x); - y = round (event_y); + gdk_win32_surface_get_root_coords (surface, event_x, event_y, &x, &y); - SendMessage (GDK_SURFACE_HWND (window), + SendMessage (GDK_SURFACE_HWND (surface), WM_SYSMENU, 0, MAKELPARAM (x * impl->surface_scale, y * impl->surface_scale)); |