[gtk+] GtkWidget: Trigger state change transitions on state flags change.
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+] GtkWidget: Trigger state change transitions on state flags change.
- Date: Sat, 4 Dec 2010 15:08:08 +0000 (UTC)
commit 227294a6aa798691ec4f5ca4f84a9796657f24d1
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 a284f84..5f22994 100644
--- a/gtk/gtkwidget.c
+++ b/gtk/gtkwidget.c
@@ -10549,7 +10549,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);
@@ -10582,7 +10582,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);
@@ -10645,6 +10647,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]