[gtk+/wip/matthiasc/gadget: 13/16] headerbar: Convert to gadgets
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/matthiasc/gadget: 13/16] headerbar: Convert to gadgets
- Date: Mon, 7 Dec 2015 16:07:59 +0000 (UTC)
commit 03a1b5d87ae85fadf0558aea256e003c81cec1c6
Author: Matthias Clasen <mclasen redhat com>
Date: Sat Dec 5 23:59:38 2015 -0500
headerbar: Convert to gadgets
gtk/gtkheaderbar.c | 228 ++++++++++++++++++++++++++++++----------------------
1 files changed, 132 insertions(+), 96 deletions(-)
---
diff --git a/gtk/gtkheaderbar.c b/gtk/gtkheaderbar.c
index 4b9882e..feb540e 100644
--- a/gtk/gtkheaderbar.c
+++ b/gtk/gtkheaderbar.c
@@ -26,7 +26,10 @@
#include "gtktypebuiltins.h"
#include "gtkwidgetprivate.h"
#include "gtkcssnodeprivate.h"
+#include "gtkcsscustomgadgetprivate.h"
#include "gtkwindowprivate.h"
+#include "gtkwidgetprivate.h"
+#include "gtkcontainerprivate.h"
#include "a11y/gtkcontaineraccessible.h"
#include <string.h>
@@ -79,6 +82,8 @@ struct _GtkHeaderBarPrivate
GtkWidget *titlebar_end_separator;
GtkWidget *titlebar_icon;
+
+ GtkCssGadget *gadget;
};
typedef struct _Child Child;
@@ -117,25 +122,6 @@ G_DEFINE_TYPE_WITH_CODE (GtkHeaderBar, gtk_header_bar, GTK_TYPE_CONTAINER,
gtk_header_bar_buildable_init));
static void
-get_css_padding_and_border (GtkWidget *widget,
- GtkBorder *border)
-{
- GtkStyleContext *context;
- GtkStateFlags state;
- GtkBorder tmp;
-
- context = gtk_widget_get_style_context (widget);
- state = gtk_widget_get_state_flags (widget);
-
- gtk_style_context_get_padding (context, state, border);
- gtk_style_context_get_border (context, state, &tmp);
- border->top += tmp.top;
- border->right += tmp.right;
- border->bottom += tmp.bottom;
- border->left += tmp.left;
-}
-
-static void
init_sizing_box (GtkHeaderBar *bar)
{
GtkHeaderBarPrivate *priv = gtk_header_bar_get_instance_private (bar);
@@ -583,29 +569,6 @@ construct_label_box (GtkHeaderBar *bar)
gtk_widget_set_parent (priv->label_box, GTK_WIDGET (bar));
}
-static void
-gtk_header_bar_init (GtkHeaderBar *bar)
-{
- GtkHeaderBarPrivate *priv;
-
- priv = gtk_header_bar_get_instance_private (bar);
-
- gtk_widget_set_has_window (GTK_WIDGET (bar), FALSE);
- gtk_widget_set_redraw_on_allocate (GTK_WIDGET (bar), FALSE);
-
- priv->title = NULL;
- priv->subtitle = NULL;
- priv->custom_title = NULL;
- priv->children = NULL;
- priv->spacing = DEFAULT_SPACING;
- priv->has_subtitle = TRUE;
- priv->decoration_layout = NULL;
- priv->decoration_layout_set = FALSE;
-
- init_sizing_box (bar);
- construct_label_box (bar);
-}
-
static gint
count_visible_children (GtkHeaderBar *bar)
{
@@ -666,7 +629,6 @@ gtk_header_bar_get_size (GtkWidget *widget,
GList *l;
gint nvis_children;
gint minimum, natural;
- GtkBorder css_borders;
gint center_min, center_nat;
minimum = natural = 0;
@@ -711,22 +673,6 @@ gtk_header_bar_get_size (GtkWidget *widget,
natural += nvis_children * priv->spacing;
}
- get_css_padding_and_border (widget, &css_borders);
-
- if (GTK_ORIENTATION_HORIZONTAL == orientation)
- {
- minimum += center_min + css_borders.left + css_borders.right;
- natural += center_nat + css_borders.left + css_borders.right;
- }
- else
- {
- /* We don't enforce css borders on the center widget, to make
- * title/subtitle combinations fit without growing the header
- */
- minimum = MAX (center_min, minimum + css_borders.top + css_borders.bottom);
- natural = MAX (center_nat, natural + css_borders.top + css_borders.bottom);
- }
-
*minimum_size = minimum;
*natural_size = natural;
}
@@ -806,11 +752,6 @@ gtk_header_bar_compute_size_for_orientation (GtkWidget *widget,
required_natural += nvis_children * priv->spacing;
}
- get_css_padding_and_border (widget, &css_borders);
-
- required_size += css_borders.left + css_borders.right;
- required_natural += css_borders.left + css_borders.right;
-
*minimum_size = required_size;
*natural_size = required_natural;
}
@@ -927,56 +868,110 @@ gtk_header_bar_compute_size_for_opposing_orientation (GtkWidget *widget,
computed_natural = MAX (computed_natural, child_natural);
}
- get_css_padding_and_border (widget, &css_borders);
-
- /* We don't enforce css borders on the center widget, to make
- * title/subtitle combinations fit without growing the header
- */
- computed_minimum = MAX (center_min, computed_minimum + css_borders.top + css_borders.bottom);
- computed_natural = MAX (center_nat, computed_natural + css_borders.top + css_borders.bottom);
-
*minimum_size = computed_minimum;
*natural_size = computed_natural;
}
static void
+gtk_header_bar_get_content_size (GtkCssGadget *gadget,
+ GtkOrientation orientation,
+ gint for_size,
+ gint *minimum,
+ gint *natural,
+ gint *minimum_baseline,
+ gint *natural_baseline,
+ gpointer unused)
+{
+ GtkWidget *widget = gtk_css_gadget_get_owner (gadget);
+
+ if (for_size < 0)
+ gtk_header_bar_get_size (widget, orientation, minimum, natural);
+ else if (orientation == GTK_ORIENTATION_HORIZONTAL)
+ gtk_header_bar_compute_size_for_orientation (widget, for_size, minimum, natural);
+ else
+ gtk_header_bar_compute_size_for_opposing_orientation (widget, for_size, minimum, natural);
+}
+
+static void
gtk_header_bar_get_preferred_width (GtkWidget *widget,
- gint *minimum_size,
- gint *natural_size)
+ gint *minimum,
+ gint *natural)
{
- gtk_header_bar_get_size (widget, GTK_ORIENTATION_HORIZONTAL, minimum_size, natural_size);
+ GtkHeaderBarPrivate *priv = gtk_header_bar_get_instance_private (GTK_HEADER_BAR (widget));
+
+ gtk_css_gadget_get_preferred_size (priv->gadget,
+ GTK_ORIENTATION_HORIZONTAL,
+ -1,
+ minimum, natural,
+ NULL, NULL);
}
static void
gtk_header_bar_get_preferred_height (GtkWidget *widget,
- gint *minimum_size,
- gint *natural_size)
+ gint *minimum,
+ gint *natural)
{
- gtk_header_bar_get_size (widget, GTK_ORIENTATION_VERTICAL, minimum_size, natural_size);
+ GtkHeaderBarPrivate *priv = gtk_header_bar_get_instance_private (GTK_HEADER_BAR (widget));
+
+ gtk_css_gadget_get_preferred_size (priv->gadget,
+ GTK_ORIENTATION_VERTICAL,
+ -1,
+ minimum, natural,
+ NULL, NULL);
}
static void
gtk_header_bar_get_preferred_width_for_height (GtkWidget *widget,
gint height,
- gint *minimum_width,
- gint *natural_width)
+ gint *minimum,
+ gint *natural)
{
- gtk_header_bar_compute_size_for_orientation (widget, height, minimum_width, natural_width);
+ GtkHeaderBarPrivate *priv = gtk_header_bar_get_instance_private (GTK_HEADER_BAR (widget));
+
+ gtk_css_gadget_get_preferred_size (priv->gadget,
+ GTK_ORIENTATION_HORIZONTAL,
+ height,
+ minimum, natural,
+ NULL, NULL);
}
static void
gtk_header_bar_get_preferred_height_for_width (GtkWidget *widget,
gint width,
- gint *minimum_height,
- gint *natural_height)
+ gint *minimum,
+ gint *natural)
{
- gtk_header_bar_compute_size_for_opposing_orientation (widget, width, minimum_height, natural_height);
+ GtkHeaderBarPrivate *priv = gtk_header_bar_get_instance_private (GTK_HEADER_BAR (widget));
+
+ gtk_css_gadget_get_preferred_size (priv->gadget,
+ GTK_ORIENTATION_VERTICAL,
+ width,
+ minimum, natural,
+ NULL, NULL);
}
static void
gtk_header_bar_size_allocate (GtkWidget *widget,
GtkAllocation *allocation)
{
+ GtkHeaderBarPrivate *priv = gtk_header_bar_get_instance_private (GTK_HEADER_BAR (widget));
+ GtkAllocation clip;
+
+ gtk_widget_set_allocation (widget, allocation);
+
+ gtk_css_gadget_allocate (priv->gadget, allocation, gtk_widget_get_allocated_baseline (widget), &clip);
+
+ gtk_widget_set_clip (widget, &clip);
+}
+
+static void
+gtk_header_bar_allocate_contents (GtkCssGadget *gadget,
+ const GtkAllocation *allocation,
+ int baseline,
+ GtkAllocation *out_clip,
+ gpointer unused)
+{
+ GtkWidget *widget = gtk_css_gadget_get_owner (gadget);
GtkHeaderBar *bar = GTK_HEADER_BAR (widget);
GtkHeaderBarPrivate *priv = gtk_header_bar_get_instance_private (bar);
GtkRequestedSize *sizes;
@@ -1002,9 +997,8 @@ gtk_header_bar_size_allocate (GtkWidget *widget,
nvis_children = count_visible_children (bar);
sizes = g_newa (GtkRequestedSize, nvis_children);
- get_css_padding_and_border (widget, &css_borders);
- width = allocation->width - nvis_children * priv->spacing - css_borders.left - css_borders.right;
- height = allocation->height - css_borders.top - css_borders.bottom;
+ width = allocation->width - nvis_children * priv->spacing;
+ height = allocation->height;
i = 0;
for (l = priv->children; l; l = l->next)
@@ -1176,7 +1170,7 @@ gtk_header_bar_size_allocate (GtkWidget *widget,
gtk_widget_size_allocate (priv->titlebar_end_box, &child_allocation);
}
- _gtk_widget_set_simple_clip (widget, NULL);
+ gtk_container_get_children_clip (GTK_CONTAINER (widget), out_clip);
}
/**
@@ -1396,6 +1390,8 @@ gtk_header_bar_finalize (GObject *object)
g_free (priv->subtitle);
g_free (priv->decoration_layout);
+ g_clear_object (&priv->gadget);
+
G_OBJECT_CLASS (gtk_header_bar_parent_class)->finalize (object);
}
@@ -1746,17 +1742,23 @@ static gint
gtk_header_bar_draw (GtkWidget *widget,
cairo_t *cr)
{
- GtkStyleContext *context;
+ GtkHeaderBarPrivate *priv = gtk_header_bar_get_instance_private (GTK_HEADER_BAR (widget));
- context = gtk_widget_get_style_context (widget);
+ gtk_css_gadget_draw (priv->gadget, cr);
- gtk_render_background (context, cr, 0, 0,
- gtk_widget_get_allocated_width (widget),
- gtk_widget_get_allocated_height (widget));
- gtk_render_frame (context, cr, 0, 0,
- gtk_widget_get_allocated_width (widget),
- gtk_widget_get_allocated_height (widget));
+ return FALSE;
+}
+static gboolean
+gtk_header_bar_render_contents (GtkCssGadget *gadget,
+ cairo_t *cr,
+ int x,
+ int y,
+ int width,
+ int height,
+ gpointer unused)
+{
+ GtkWidget *widget = gtk_css_gadget_get_owner (gadget);
GTK_WIDGET_CLASS (gtk_header_bar_parent_class)->draw (widget, cr);
@@ -1977,6 +1979,40 @@ gtk_header_bar_class_init (GtkHeaderBarClass *class)
}
static void
+gtk_header_bar_init (GtkHeaderBar *bar)
+{
+ GtkHeaderBarPrivate *priv;
+ GtkCssNode *widget_node;
+
+ priv = gtk_header_bar_get_instance_private (bar);
+
+ gtk_widget_set_has_window (GTK_WIDGET (bar), FALSE);
+ gtk_widget_set_redraw_on_allocate (GTK_WIDGET (bar), FALSE);
+
+ priv->title = NULL;
+ priv->subtitle = NULL;
+ priv->custom_title = NULL;
+ priv->children = NULL;
+ priv->spacing = DEFAULT_SPACING;
+ priv->has_subtitle = TRUE;
+ priv->decoration_layout = NULL;
+ priv->decoration_layout_set = FALSE;
+
+ init_sizing_box (bar);
+ construct_label_box (bar);
+
+ widget_node = gtk_widget_get_css_node (GTK_WIDGET (bar));
+ priv->gadget = gtk_css_custom_gadget_new_for_node (widget_node,
+ GTK_WIDGET (bar),
+ gtk_header_bar_get_content_size,
+ gtk_header_bar_allocate_contents,
+ gtk_header_bar_render_contents,
+ NULL,
+ NULL);
+
+}
+
+static void
gtk_header_bar_buildable_add_child (GtkBuildable *buildable,
GtkBuilder *builder,
GObject *child,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]