Fix the coordinates in crossing events so they are relative to the right

2007-06-01  Richard Hult  <richard@imendio.com>

	* gdk/quartz/gdkevents-quartz.c:
	(get_converted_window_coordinates), (create_crossing_event): Fix the
	coordinates in crossing events so they are relative to the right
	window.

svn path=/trunk/; revision=18007
This commit is contained in:
Richard Hult 2007-06-01 21:46:45 +00:00 committed by Richard Hult
parent be540c29ac
commit 1c413a691c
2 changed files with 113 additions and 15 deletions

View File

@ -1,3 +1,10 @@
2007-06-01 Richard Hult <richard@imendio.com>
* gdk/quartz/gdkevents-quartz.c:
(get_converted_window_coordinates), (create_crossing_event): Fix the
coordinates in crossing events so they are relative to the right
window.
2007-06-01 Richard Hult <richard@imendio.com> 2007-06-01 Richard Hult <richard@imendio.com>
* gdk/quartz/gdkevents-quartz.[ch]: Make function naming * gdk/quartz/gdkevents-quartz.[ch]: Make function naming

View File

@ -30,26 +30,43 @@
#include "gdkscreen.h" #include "gdkscreen.h"
#include "gdkkeysyms.h" #include "gdkkeysyms.h"
#include "gdkprivate-quartz.h" #include "gdkprivate-quartz.h"
/* This is the window the mouse is currently over */ /* This is the window the mouse is currently over */
static GdkWindow *current_mouse_window; static GdkWindow *current_mouse_window;
/* This is the window corresponding to the key window */ /* This is the window corresponding to the key window */
static GdkWindow *current_keyboard_window; static GdkWindow *current_keyboard_window;
/* This is the pointer grab window */ /* This is the pointer grab window */
GdkWindow *_gdk_quartz_pointer_grab_window; GdkWindow *_gdk_quartz_pointer_grab_window;
static gboolean pointer_grab_owner_events; static gboolean pointer_grab_owner_events;
static GdkEventMask pointer_grab_event_mask; static GdkEventMask pointer_grab_event_mask;
static gboolean pointer_grab_implicit; static gboolean pointer_grab_implicit;
/* This is the keyboard grab window */ /* This is the keyboard grab window */
GdkWindow *_gdk_quartz_keyboard_grab_window; GdkWindow * _gdk_quartz_keyboard_grab_window;
static gboolean keyboard_grab_owner_events; static gboolean keyboard_grab_owner_events;
static void append_event (GdkEvent *event); static void get_child_coordinates_from_ancestor (GdkWindow *ancestor_window,
gint ancestor_x,
gint ancestor_y,
GdkWindow *child_window,
gint *child_x,
gint *child_y);
static void get_ancestor_coordinates_from_child (GdkWindow *child_window,
gint child_x,
gint child_y,
GdkWindow *ancestor_window,
gint *ancestor_x,
gint *ancestor_y);
static void get_converted_window_coordinates (GdkWindow *in_window,
gint in_x,
gint in_y,
GdkWindow *out_window,
gint *out_x,
gint *out_y);
static void append_event (GdkEvent *event);
void void
_gdk_events_init (void) _gdk_events_init (void)
@ -533,6 +550,7 @@ convert_window_coordinates_to_root (GdkWindow *window,
} }
} }
/* FIXME: Refactor and share with scroll event. */
static GdkEvent * static GdkEvent *
create_crossing_event (GdkWindow *window, create_crossing_event (GdkWindow *window,
NSEvent *nsevent, NSEvent *nsevent,
@ -541,7 +559,7 @@ create_crossing_event (GdkWindow *window,
GdkNotifyType detail) GdkNotifyType detail)
{ {
GdkEvent *event; GdkEvent *event;
NSPoint point; gint x_tmp, y_tmp;
event = gdk_event_new (event_type); event = gdk_event_new (event_type);
@ -549,10 +567,42 @@ create_crossing_event (GdkWindow *window,
event->crossing.subwindow = NULL; /* FIXME */ event->crossing.subwindow = NULL; /* FIXME */
event->crossing.time = get_time_from_ns_event (nsevent); event->crossing.time = get_time_from_ns_event (nsevent);
point = [nsevent locationInWindow]; /* Split out this block: */
event->crossing.x = point.x; {
event->crossing.y = point.y; NSWindow *nswindow;
convert_window_coordinates_to_root (window, event->crossing.x, event->crossing.y, GdkWindow *toplevel;
NSPoint point;
nswindow = [nsevent window];
point = [nsevent locationInWindow];
toplevel = [(GdkQuartzView *)[nswindow contentView] gdkWindow];
x_tmp = point.x;
/* Flip the y coordinate. */
if (toplevel == _gdk_root)
y_tmp = _gdk_quartz_window_get_inverted_screen_y (point.y);
else
{
GdkWindowImplQuartz *impl;
impl = GDK_WINDOW_IMPL_QUARTZ (GDK_WINDOW_OBJECT (toplevel)->impl);
y_tmp = impl->height - point.y;
}
get_converted_window_coordinates (toplevel,
x_tmp, y_tmp,
window,
&x_tmp, &y_tmp);
}
event->crossing.x = x_tmp;
event->crossing.y = y_tmp;
convert_window_coordinates_to_root (window,
event->crossing.x,
event->crossing.y,
&event->crossing.x_root, &event->crossing.x_root,
&event->crossing.y_root); &event->crossing.y_root);
@ -841,6 +891,47 @@ get_ancestor_coordinates_from_child (GdkWindow *child_window,
*ancestor_y = child_y; *ancestor_y = child_y;
} }
/* Translates coordinates relative to one window (in_window) into
* coordinates relative to another window (out_window).
*/
static void
get_converted_window_coordinates (GdkWindow *in_window,
gint in_x,
gint in_y,
GdkWindow *out_window,
gint *out_x,
gint *out_y)
{
GdkWindow *in_toplevel;
GdkWindow *out_toplevel;
int in_origin_x, in_origin_y;
int out_origin_x, out_origin_y;
/* First translate to "in" toplevel coordinates, then on to "out"
* toplevel coordinates, and finally to "out" child (the passed in
* window) coordinates.
*/
in_toplevel = gdk_window_get_toplevel (in_window);
out_toplevel = gdk_window_get_toplevel (out_window);
/* Translate in_x, in_y to "in" toplevel coordinates. */
get_ancestor_coordinates_from_child (in_window, in_x, in_y,
in_toplevel, &in_x, &in_y);
gdk_window_get_origin (in_toplevel, &in_origin_x, &in_origin_y);
gdk_window_get_origin (out_toplevel, &out_origin_x, &out_origin_y);
/* Translate in_x, in_y to "out" toplevel coordinates. */
in_x -= out_origin_x - in_origin_x;
in_y -= out_origin_y - in_origin_y;
get_child_coordinates_from_ancestor (out_toplevel,
in_x, in_y,
out_window,
out_x, out_y);
}
/* Given a mouse NSEvent, returns the window in which the pointer /* Given a mouse NSEvent, returns the window in which the pointer
* position from the event is. The returned coordinates are relative * position from the event is. The returned coordinates are relative
* to the found window, and normal GDK coordinates, not Quartz. * to the found window, and normal GDK coordinates, not Quartz.