[gtk+/gtk-style-context: 306/533] GtkWidget: Trigger state change transitions on state flags change.
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/gtk-style-context: 306/533] GtkWidget: Trigger state change transitions on state flags change.
- Date: Wed, 1 Dec 2010 02:31:32 +0000 (UTC)
commit a490fbb40ced095eab4190f3afc7f6c4e4b0cc09
Author: Carlos Garnacho <carlosg gnome org>
Date: Mon Nov 1 02:37:07 2010 +0100
GtkWidget: Trigger state change transitions on state flags change.
This makes state transitions automatic for non-complex widgets, complex
widgets such as GtkTreeView still need to notify state updates themselves.
gtk/gtkwidget.c | 59 +++++++++++++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 57 insertions(+), 2 deletions(-)
---
diff --git a/gtk/gtkwidget.c b/gtk/gtkwidget.c
index 166ab46..3c92ea4 100644
--- a/gtk/gtkwidget.c
+++ b/gtk/gtkwidget.c
@@ -10579,7 +10579,7 @@ gtk_widget_propagate_state (GtkWidget *widget,
GtkStateData *data)
{
GtkWidgetPrivate *priv = widget->priv;
- GtkStateFlags old_flags = priv->state_flags;
+ GtkStateFlags new_flags, old_flags = priv->state_flags;
GtkStateType old_state;
old_state = gtk_widget_get_state (widget);
@@ -10612,7 +10612,9 @@ gtk_widget_propagate_state (GtkWidget *widget,
gtk_window_set_focus (GTK_WINDOW (window), NULL);
}
- if (old_flags != gtk_widget_get_state_flags (widget))
+ new_flags = gtk_widget_get_state_flags (widget);
+
+ if (old_flags != new_flags)
{
g_object_ref (widget);
@@ -10675,6 +10677,59 @@ gtk_widget_propagate_state (GtkWidget *widget,
data);
}
+ /* Trigger state change transitions for the widget */
+ if (priv->context &&
+ gtk_widget_get_mapped (widget))
+ {
+ gint diff, flag = 1;
+ GdkWindow *window;
+
+ diff = old_flags ^ new_flags;
+ window = gtk_widget_get_window (widget);
+
+ while (diff != 0)
+ {
+ if ((diff & flag) != 0)
+ {
+ GtkStateType state;
+ gboolean target;
+
+ switch (flag)
+ {
+ case GTK_STATE_FLAG_ACTIVE:
+ state = GTK_STATE_ACTIVE;
+ break;
+ case GTK_STATE_FLAG_PRELIGHT:
+ state = GTK_STATE_PRELIGHT;
+ break;
+ case GTK_STATE_FLAG_SELECTED:
+ state = GTK_STATE_SELECTED;
+ break;
+ case GTK_STATE_FLAG_INSENSITIVE:
+ state = GTK_STATE_INSENSITIVE;
+ break;
+ case GTK_STATE_FLAG_INCONSISTENT:
+ state = GTK_STATE_INCONSISTENT;
+ break;
+ case GTK_STATE_FLAG_FOCUSED:
+ state = GTK_STATE_FOCUSED;
+ break;
+ default:
+ state = GTK_STATE_NORMAL;
+ break;
+ }
+
+ target = ((new_flags & flag) != 0);
+ gtk_style_context_notify_state_change (priv->context,
+ window, NULL,
+ state, target);
+ diff &= ~flag;
+ }
+
+ flag <<= 1;
+ }
+ }
+
g_object_unref (widget);
}
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]