# HG changeset patch # User nadvornik # Date 1248820044 0 # Node ID 51820482c7e5c56e594fb9fa74ba426bf7e93a70 # Parent 30eb78c26e9bc979a428ba627f717b74bb2e5d17 improved scroll on slower machines patch by Stanislav Brabec diff -r 30eb78c26e9b -r 51820482c7e5 src/pixbuf-renderer.c --- a/src/pixbuf-renderer.c Tue Jul 28 22:14:26 2009 +0000 +++ b/src/pixbuf-renderer.c Tue Jul 28 22:27:24 2009 +0000 @@ -3746,6 +3746,13 @@ PixbufRenderer *pr; gint accel; + /* This is a hack, but work far the best, at least for single pointer systems. + * See http://bugzilla.gnome.org/show_bug.cgi?id=587714 for more. */ + gint x, y; + gdk_window_get_pointer (bevent->window, &x, &y, NULL); + bevent->x = x; + bevent->y = y; + pr = PIXBUF_RENDERER(widget); if (pr->scroller_id) @@ -3787,6 +3794,11 @@ pr->drag_last_x = bevent->x; pr->drag_last_y = bevent->y; + /* This is recommended by the GTK+ documentation, but does not work properly. + * Use deprecated way until GTK+ gets a solution for correct motion hint handling: + * http://bugzilla.gnome.org/show_bug.cgi?id=587714 + */ + /* gdk_event_request_motions (bevent); */ return FALSE; } @@ -3807,7 +3819,7 @@ pr->drag_last_y = bevent->y; pr->drag_moved = 0; gdk_pointer_grab(widget->window, FALSE, - GDK_POINTER_MOTION_MASK | GDK_BUTTON_RELEASE_MASK, + GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_RELEASE_MASK, NULL, NULL, bevent->time); gtk_grab_add(widget); break; @@ -3905,7 +3917,7 @@ g_signal_connect(G_OBJECT(pr), "hierarchy-changed", G_CALLBACK(pr_hierarchy_changed_cb), pr); - gtk_widget_set_events(GTK_WIDGET(pr), GDK_POINTER_MOTION_MASK | + gtk_widget_set_events(GTK_WIDGET(pr), GDK_POINTER_MOTION_MASK | GDK_POINTER_MOTION_HINT_MASK | GDK_BUTTON_RELEASE_MASK | GDK_BUTTON_PRESS_MASK | GDK_LEAVE_NOTIFY_MASK);