GtkRange: Make drag gesture less agressive
Moving the mouse while pressing one of the steppers was making the slider jump to the end, unexpectedly. This was caused by the drag gesture kicking in when it shouldn't. Fix this by making all drag gesture signal handlers only do something if we are in a drag thats started on the slider. https://bugzilla.gnome.org/show_bug.cgi?id=751050
This commit is contained in:
parent
b4a88c7287
commit
27dabaefa6
@ -2397,7 +2397,6 @@ coord_to_value (GtkRange *range,
|
|||||||
value = gtk_adjustment_get_lower (priv->adjustment) + frac * (gtk_adjustment_get_upper (priv->adjustment) -
|
value = gtk_adjustment_get_lower (priv->adjustment) + frac * (gtk_adjustment_get_upper (priv->adjustment) -
|
||||||
gtk_adjustment_get_lower (priv->adjustment) -
|
gtk_adjustment_get_lower (priv->adjustment) -
|
||||||
gtk_adjustment_get_page_size (priv->adjustment));
|
gtk_adjustment_get_page_size (priv->adjustment));
|
||||||
|
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2925,6 +2924,8 @@ gtk_range_drag_gesture_update (GtkGestureDrag *gesture,
|
|||||||
GtkRangePrivate *priv = range->priv;
|
GtkRangePrivate *priv = range->priv;
|
||||||
gdouble start_x, start_y;
|
gdouble start_x, start_y;
|
||||||
|
|
||||||
|
if (range->priv->grab_location == MOUSE_SLIDER)
|
||||||
|
{
|
||||||
gtk_gesture_drag_get_start_point (gesture, &start_x, &start_y);
|
gtk_gesture_drag_get_start_point (gesture, &start_x, &start_y);
|
||||||
priv->mouse_x = start_x + offset_x;
|
priv->mouse_x = start_x + offset_x;
|
||||||
priv->mouse_y = start_y + offset_y;
|
priv->mouse_y = start_y + offset_y;
|
||||||
@ -2934,6 +2935,7 @@ gtk_range_drag_gesture_update (GtkGestureDrag *gesture,
|
|||||||
|
|
||||||
if (priv->autoscroll_mode == GTK_SCROLL_NONE)
|
if (priv->autoscroll_mode == GTK_SCROLL_NONE)
|
||||||
update_slider_position (range, priv->mouse_x, priv->mouse_y);
|
update_slider_position (range, priv->mouse_x, priv->mouse_y);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -2952,8 +2954,11 @@ gtk_range_drag_gesture_end (GtkGestureDrag *gesture,
|
|||||||
gdouble offset_y,
|
gdouble offset_y,
|
||||||
GtkRange *range)
|
GtkRange *range)
|
||||||
{
|
{
|
||||||
|
if (range->priv->grab_location == MOUSE_SLIDER)
|
||||||
|
{
|
||||||
range->priv->in_drag = FALSE;
|
range->priv->in_drag = FALSE;
|
||||||
stop_scrolling (range);
|
stop_scrolling (range);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
Loading…
Reference in New Issue
Block a user