[mutter/wip/gtk-theming: 7/20] theme: Add method to adjust styles for frame state



commit c42520f39d96bb711ed58fd803cfebaf55ec9607
Author: Florian Müllner <fmuellner gnome org>
Date:   Thu Sep 25 06:41:40 2014 +0200

    theme: Add method to adjust styles for frame state
    
    GTK+ expresses the window state as style classes and widget state for
    client-side decorations. Add a helper method to translate our own frame
    state to the corresponding changes to the style context hierarchy.

 src/ui/theme-private.h |    3 ++
 src/ui/theme.c         |   71 ++++++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 74 insertions(+), 0 deletions(-)
---
diff --git a/src/ui/theme-private.h b/src/ui/theme-private.h
index ac5a31d..10a12b5 100644
--- a/src/ui/theme-private.h
+++ b/src/ui/theme-private.h
@@ -1049,6 +1049,9 @@ MetaStyleInfo * meta_theme_create_style_info (GdkScreen   *screen,
 MetaStyleInfo * meta_style_info_ref          (MetaStyleInfo *style);
 void            meta_style_info_unref        (MetaStyleInfo  *style_info);
 
+void            meta_style_info_set_flags    (MetaStyleInfo  *style_info,
+                                              MetaFrameFlags  flags);
+
 PangoFontDescription * meta_style_info_create_font_desc (MetaStyleInfo *style_info);
 
 void meta_theme_draw_frame (MetaTheme              *theme,
diff --git a/src/ui/theme.c b/src/ui/theme.c
index 790d933..3973b28 100644
--- a/src/ui/theme.c
+++ b/src/ui/theme.c
@@ -5113,6 +5113,77 @@ meta_style_info_unref (MetaStyleInfo *style_info)
     }
 }
 
+static void
+add_toplevel_class (GtkStyleContext *style,
+                    const char      *class_name)
+{
+  if (gtk_style_context_get_parent (style))
+    {
+      GtkWidgetPath *path;
+
+      path = gtk_widget_path_copy (gtk_style_context_get_path (style));
+      gtk_widget_path_iter_add_class (path, 0, class_name);
+      gtk_style_context_set_path (style, path);
+      gtk_widget_path_unref (path);
+    }
+  else
+    gtk_style_context_add_class (style, class_name);
+}
+
+static void
+remove_toplevel_class (GtkStyleContext *style,
+                       const char      *class_name)
+{
+  if (gtk_style_context_get_parent (style))
+    {
+      GtkWidgetPath *path;
+
+      path = gtk_widget_path_copy (gtk_style_context_get_path (style));
+      gtk_widget_path_iter_remove_class (path, 0, class_name);
+      gtk_style_context_set_path (style, path);
+      gtk_widget_path_unref (path);
+    }
+  else
+    gtk_style_context_remove_class (style, class_name);
+}
+
+void
+meta_style_info_set_flags (MetaStyleInfo  *style_info,
+                           MetaFrameFlags  flags)
+{
+  GtkStyleContext *style;
+  const char *class_name = NULL;
+  gboolean backdrop;
+  GtkStateFlags state;
+  int i;
+
+  backdrop = !(flags & META_FRAME_HAS_FOCUS);
+  if (flags & META_FRAME_IS_FLASHING)
+    backdrop = !backdrop;
+
+  if (flags & META_FRAME_MAXIMIZED)
+    class_name = "maximized";
+  else if (flags & META_FRAME_TILED_LEFT ||
+           flags & META_FRAME_TILED_RIGHT)
+    class_name = "tiled";
+
+  for (i = 0; i < META_STYLE_ELEMENT_LAST; i++)
+    {
+      style = style_info->styles[i];
+
+      state = gtk_style_context_get_state (style);
+      gtk_style_context_set_state (style,
+                                   backdrop ? state | GTK_STATE_FLAG_BACKDROP
+                                            : state & ~GTK_STATE_FLAG_BACKDROP);
+
+      remove_toplevel_class (style, "maximized");
+      remove_toplevel_class (style, "tiled");
+
+      if (class_name)
+        add_toplevel_class (style, class_name);
+    }
+}
+
 PangoFontDescription*
 meta_style_info_create_font_desc (MetaStyleInfo *style_info)
 {


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]