mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-14 22:30:22 +00:00
spin button: Stop using ::focus-out-event
Just use the generic ::event signal.
This commit is contained in:
parent
4f3065a5e8
commit
5cb1c606bb
@ -258,8 +258,8 @@ static void gtk_spin_button_size_allocate (GtkWidget *widget,
|
|||||||
const GtkAllocation *allocation,
|
const GtkAllocation *allocation,
|
||||||
int baseline,
|
int baseline,
|
||||||
GtkAllocation *out_clip);
|
GtkAllocation *out_clip);
|
||||||
static gint gtk_spin_button_focus_out (GtkWidget *widget,
|
static gboolean gtk_spin_button_event (GtkWidget *widget,
|
||||||
GdkEventFocus *event);
|
GdkEvent *event);
|
||||||
static void gtk_spin_button_grab_notify (GtkWidget *widget,
|
static void gtk_spin_button_grab_notify (GtkWidget *widget,
|
||||||
gboolean was_grabbed);
|
gboolean was_grabbed);
|
||||||
static void gtk_spin_button_state_flags_changed (GtkWidget *widget,
|
static void gtk_spin_button_state_flags_changed (GtkWidget *widget,
|
||||||
@ -321,7 +321,7 @@ gtk_spin_button_class_init (GtkSpinButtonClass *class)
|
|||||||
widget_class->measure = gtk_spin_button_measure;
|
widget_class->measure = gtk_spin_button_measure;
|
||||||
widget_class->size_allocate = gtk_spin_button_size_allocate;
|
widget_class->size_allocate = gtk_spin_button_size_allocate;
|
||||||
widget_class->key_release_event = gtk_spin_button_key_release;
|
widget_class->key_release_event = gtk_spin_button_key_release;
|
||||||
widget_class->focus_out_event = gtk_spin_button_focus_out;
|
widget_class->event = gtk_spin_button_event;
|
||||||
widget_class->grab_notify = gtk_spin_button_grab_notify;
|
widget_class->grab_notify = gtk_spin_button_grab_notify;
|
||||||
widget_class->state_flags_changed = gtk_spin_button_state_flags_changed;
|
widget_class->state_flags_changed = gtk_spin_button_state_flags_changed;
|
||||||
|
|
||||||
@ -1086,16 +1086,27 @@ gtk_spin_button_size_allocate (GtkWidget *widget,
|
|||||||
gtk_widget_size_allocate (priv->box, allocation, baseline, out_clip);
|
gtk_widget_size_allocate (priv->box, allocation, baseline, out_clip);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gint
|
static gboolean
|
||||||
gtk_spin_button_focus_out (GtkWidget *widget,
|
gtk_spin_button_event (GtkWidget *widget,
|
||||||
GdkEventFocus *event)
|
GdkEvent *event)
|
||||||
{
|
{
|
||||||
GtkSpinButton *spin_button = GTK_SPIN_BUTTON (widget);
|
GtkSpinButton *spin_button = GTK_SPIN_BUTTON (widget);
|
||||||
|
|
||||||
if (gtk_editable_get_editable (GTK_EDITABLE (spin_button->priv->entry)))
|
if (gdk_event_get_event_type (event) == GDK_FOCUS_CHANGE)
|
||||||
gtk_spin_button_update (spin_button);
|
{
|
||||||
|
gboolean focus_in;
|
||||||
|
|
||||||
return GTK_WIDGET_CLASS (gtk_spin_button_parent_class)->focus_out_event (widget, event);
|
gdk_event_get_focus_in (event, &focus_in);
|
||||||
|
if (!focus_in)
|
||||||
|
{
|
||||||
|
if (gtk_editable_get_editable (GTK_EDITABLE (spin_button->priv->entry)))
|
||||||
|
gtk_spin_button_update (spin_button);
|
||||||
|
}
|
||||||
|
|
||||||
|
return GDK_EVENT_PROPAGATE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return GDK_EVENT_PROPAGATE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
Loading…
Reference in New Issue
Block a user