mir: stop forwarding motion events to subwindows

This commit is contained in:
William Hua
2015-01-07 12:18:03 -05:00
parent 901bc2957d
commit c2afa674e2
3 changed files with 0 additions and 136 deletions

View File

@ -292,44 +292,6 @@ handle_key_event (GdkWindow *window, const MirKeyEvent *event)
}
}
/* TODO: Remove once we have proper transient window support. */
typedef struct
{
gdouble x;
gdouble y;
guint32 event_time;
gboolean cursor_inside;
} LeaveInfo;
/* TODO: Remove once we have proper transient window support. */
static void
generate_leave_events (GdkWindow *window,
LeaveInfo *user_data)
{
GdkMirWindowImpl *impl = GDK_MIR_WINDOW_IMPL (window->impl);
LeaveInfo info = *user_data;
gdouble x;
gdouble y;
gboolean cursor_inside;
MirMotionButton button_state;
info.x -= window->x;
info.y -= window->y;
if (info.cursor_inside)
info.cursor_inside = 0 <= info.x && info.x < window->width && 0 <= info.y && info.y < window->height;
_gdk_mir_window_impl_get_cursor_state (impl, &x, &y, &cursor_inside, &button_state);
if (cursor_inside && !info.cursor_inside)
{
_gdk_mir_window_impl_set_cursor_state (impl, x, y, FALSE, button_state);
generate_crossing_event (window, GDK_LEAVE_NOTIFY, info.x, info.y, info.event_time);
}
_gdk_mir_window_transient_children_foreach (window, (GFunc) generate_leave_events, &info);
}
static void
handle_motion_event (GdkWindow *window, const MirMotionEvent *event)
{
@ -351,26 +313,6 @@ handle_motion_event (GdkWindow *window, const MirMotionEvent *event)
modifier_state = get_modifier_state (event->modifiers, event->button_state);
event_time = NANO_TO_MILLI (event->event_time);
/* TODO: Remove once we have proper transient window support. */
{
LeaveInfo info;
info.x = x;
info.y = y;
info.event_time = event_time;
info.cursor_inside = TRUE;
_gdk_mir_window_transient_children_foreach (window, (GFunc) generate_leave_events, &info);
}
/* The Mir events generate hover-exits even while inside the window so
counteract this by always generating an enter notify on all other events */
if (!cursor_inside && event->action != mir_motion_action_hover_exit)
{
cursor_inside = TRUE;
generate_crossing_event (window, GDK_ENTER_NOTIFY, x, y, event_time);
}
/* Update which window has focus */
_gdk_mir_pointer_set_location (get_pointer (window), x, y, window, modifier_state);
switch (event->action)
@ -536,28 +478,6 @@ gdk_mir_event_source_convert_events (GdkMirEventSource *source)
*/
if (window != NULL)
{
/* TODO: Remove once we have proper transient window support. */
if (event->event.type == mir_event_type_motion)
{
GdkWindow *child;
gint x;
gint y;
x = event->event.motion.pointer_coordinates[0].x;
y = event->event.motion.pointer_coordinates[0].y;
child = _gdk_mir_window_get_visible_transient_child (window, x, y, &x, &y);
if (child && child != window)
{
window = child;
event->event.motion.pointer_count = MAX (event->event.motion.pointer_count, 1);
event->event.motion.pointer_coordinates[0].x = x;
event->event.motion.pointer_coordinates[0].y = y;
}
}
if (source->log_events)
_gdk_mir_print_event (&event->event);