mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-05 02:11:08 +00:00
switch: Remove in_switch flag
It's pretty simple and less code to just check whether the gesture coords are inside the widget at the one place where we actually used the flag.
This commit is contained in:
parent
63ba8fa355
commit
24abbac114
@ -85,7 +85,6 @@ struct _GtkSwitchPrivate
|
|||||||
|
|
||||||
guint state : 1;
|
guint state : 1;
|
||||||
guint is_active : 1;
|
guint is_active : 1;
|
||||||
guint in_switch : 1;
|
|
||||||
|
|
||||||
GtkWidget *on_label;
|
GtkWidget *on_label;
|
||||||
GtkWidget *off_label;
|
GtkWidget *off_label;
|
||||||
@ -209,12 +208,14 @@ gtk_switch_multipress_gesture_released (GtkGestureMultiPress *gesture,
|
|||||||
gdouble y,
|
gdouble y,
|
||||||
GtkSwitch *sw)
|
GtkSwitch *sw)
|
||||||
{
|
{
|
||||||
GtkSwitchPrivate *priv = sw->priv;
|
|
||||||
GdkEventSequence *sequence;
|
GdkEventSequence *sequence;
|
||||||
|
GdkRectangle own_alloc;
|
||||||
|
|
||||||
sequence = gtk_gesture_single_get_current_sequence (GTK_GESTURE_SINGLE (gesture));
|
sequence = gtk_gesture_single_get_current_sequence (GTK_GESTURE_SINGLE (gesture));
|
||||||
|
|
||||||
if (priv->in_switch &&
|
gtk_widget_get_own_allocation (GTK_WIDGET (sw), &own_alloc);
|
||||||
|
|
||||||
|
if (gdk_rectangle_contains_point (&own_alloc, x, y) &&
|
||||||
gtk_gesture_handles_sequence (GTK_GESTURE (gesture), sequence))
|
gtk_gesture_handles_sequence (GTK_GESTURE (gesture), sequence))
|
||||||
gtk_switch_begin_toggle_animation (sw);
|
gtk_switch_begin_toggle_animation (sw);
|
||||||
}
|
}
|
||||||
@ -277,28 +278,6 @@ gtk_switch_pan_gesture_drag_end (GtkGestureDrag *gesture,
|
|||||||
gtk_widget_queue_allocate (GTK_WIDGET (sw));
|
gtk_widget_queue_allocate (GTK_WIDGET (sw));
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
|
||||||
gtk_switch_enter (GtkWidget *widget,
|
|
||||||
GdkEventCrossing *event)
|
|
||||||
{
|
|
||||||
GtkSwitchPrivate *priv = GTK_SWITCH (widget)->priv;
|
|
||||||
|
|
||||||
priv->in_switch = TRUE;
|
|
||||||
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static gboolean
|
|
||||||
gtk_switch_leave (GtkWidget *widget,
|
|
||||||
GdkEventCrossing *event)
|
|
||||||
{
|
|
||||||
GtkSwitchPrivate *priv = GTK_SWITCH (widget)->priv;
|
|
||||||
|
|
||||||
priv->in_switch = FALSE;
|
|
||||||
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gtk_switch_activate (GtkSwitch *sw)
|
gtk_switch_activate (GtkSwitch *sw)
|
||||||
{
|
{
|
||||||
@ -593,8 +572,6 @@ gtk_switch_class_init (GtkSwitchClass *klass)
|
|||||||
widget_class->measure = gtk_switch_measure;
|
widget_class->measure = gtk_switch_measure;
|
||||||
widget_class->size_allocate = gtk_switch_size_allocate;
|
widget_class->size_allocate = gtk_switch_size_allocate;
|
||||||
widget_class->snapshot = gtk_switch_snapshot;
|
widget_class->snapshot = gtk_switch_snapshot;
|
||||||
widget_class->enter_notify_event = gtk_switch_enter;
|
|
||||||
widget_class->leave_notify_event = gtk_switch_leave;
|
|
||||||
|
|
||||||
klass->activate = gtk_switch_activate;
|
klass->activate = gtk_switch_activate;
|
||||||
klass->state_set = state_set;
|
klass->state_set = state_set;
|
||||||
|
Loading…
Reference in New Issue
Block a user