[gtk+/wip/otte/rendernode] snapshot: Convert Range, Scale, ColorScale
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/otte/rendernode] snapshot: Convert Range, Scale, ColorScale
- Date: Thu, 15 Dec 2016 09:19:30 +0000 (UTC)
commit 39a39474fe0f6b49aca5d5fd28af6e50581f4266
Author: Benjamin Otte <otte redhat com>
Date: Thu Dec 15 10:09:41 2016 +0100
snapshot: Convert Range, Scale, ColorScale
And of course Scrollbar, but that one does no drawing itself.
gtk/gtkcolorscale.c | 26 ++++++++--------
gtk/gtkcolorscaleprivate.h | 12 ++++----
gtk/gtkrange.c | 38 +++++++++++------------
gtk/gtkscale.c | 70 ++++++++++++++++++++++---------------------
4 files changed, 73 insertions(+), 73 deletions(-)
---
diff --git a/gtk/gtkcolorscale.c b/gtk/gtkcolorscale.c
index e1bf973..b6560a7 100644
--- a/gtk/gtkcolorscale.c
+++ b/gtk/gtkcolorscale.c
@@ -29,6 +29,7 @@
#include "gtkprivate.h"
#include "gtkintl.h"
#include "gtkrenderprivate.h"
+#include "gtksnapshot.h"
#include <math.h>
@@ -54,25 +55,24 @@ static void hold_action (GtkGestureLongPress *gesture,
G_DEFINE_TYPE_WITH_PRIVATE (GtkColorScale, gtk_color_scale, GTK_TYPE_SCALE)
void
-gtk_color_scale_draw_trough (GtkColorScale *scale,
- cairo_t *cr,
- int x,
- int y,
- int width,
- int height)
+gtk_color_scale_snapshot_trough (GtkColorScale *scale,
+ GtkSnapshot *snapshot,
+ int x,
+ int y,
+ int width,
+ int height)
{
- GtkWidget *widget;
+ GtkWidget *widget = GTK_WIDGET (scale);
+ cairo_t *cr;
if (width <= 1 || height <= 1)
return;
- cairo_save (cr);
+ cr = gtk_snapshot_append_cairo_node (snapshot,
+ &GRAPHENE_RECT_INIT(x, y, width, height),
+ "ColorScaleTrough");
cairo_translate (cr, x, y);
- widget = GTK_WIDGET (scale);
- cairo_rectangle (cr, 0, 0, width, height);
- cairo_clip (cr);
-
if (gtk_orientable_get_orientation (GTK_ORIENTABLE (widget)) == GTK_ORIENTATION_HORIZONTAL &&
gtk_widget_get_direction (widget) == GTK_TEXT_DIR_RTL)
{
@@ -145,7 +145,7 @@ gtk_color_scale_draw_trough (GtkColorScale *scale,
cairo_pattern_destroy (pattern);
}
- cairo_restore (cr);
+ cairo_destroy (cr);
}
static void
diff --git a/gtk/gtkcolorscaleprivate.h b/gtk/gtkcolorscaleprivate.h
index 15b3324..e1a5425 100644
--- a/gtk/gtkcolorscaleprivate.h
+++ b/gtk/gtkcolorscaleprivate.h
@@ -64,12 +64,12 @@ GtkWidget * gtk_color_scale_new (GtkAdjustment *adjustment,
void gtk_color_scale_set_rgba (GtkColorScale *scale,
const GdkRGBA *color);
-void gtk_color_scale_draw_trough (GtkColorScale *scale,
- cairo_t *cr,
- int x,
- int y,
- int width,
- int height);
+void gtk_color_scale_snapshot_trough (GtkColorScale *scale,
+ GtkSnapshot *snapshot,
+ int x,
+ int y,
+ int width,
+ int height);
G_END_DECLS
diff --git a/gtk/gtkrange.c b/gtk/gtkrange.c
index a7658e2..cfb4ff4 100644
--- a/gtk/gtkrange.c
+++ b/gtk/gtkrange.c
@@ -190,8 +190,8 @@ static void gtk_range_realize (GtkWidget *widget);
static void gtk_range_unrealize (GtkWidget *widget);
static void gtk_range_map (GtkWidget *widget);
static void gtk_range_unmap (GtkWidget *widget);
-static gboolean gtk_range_draw (GtkWidget *widget,
- cairo_t *cr);
+static void gtk_range_snapshot (GtkWidget *widget,
+ GtkSnapshot *snapshot);
static void gtk_range_multipress_gesture_pressed (GtkGestureMultiPress *gesture,
guint n_press,
@@ -273,7 +273,7 @@ static void gtk_range_allocate_trough (GtkCssGadget *ga
GtkAllocation *out_clip,
gpointer data);
static gboolean gtk_range_render_trough (GtkCssGadget *gadget,
- cairo_t *cr,
+ GtkSnapshot *snapshot,
int x,
int y,
int width,
@@ -293,7 +293,7 @@ static void gtk_range_allocate (GtkCssGadget *ga
GtkAllocation *out_clip,
gpointer data);
static gboolean gtk_range_render (GtkCssGadget *gadget,
- cairo_t *cr,
+ GtkSnapshot *snapshot,
int x,
int y,
int width,
@@ -328,7 +328,7 @@ gtk_range_class_init (GtkRangeClass *class)
widget_class->unrealize = gtk_range_unrealize;
widget_class->map = gtk_range_map;
widget_class->unmap = gtk_range_unmap;
- widget_class->draw = gtk_range_draw;
+ widget_class->snapshot = gtk_range_snapshot;
widget_class->event = gtk_range_event;
widget_class->scroll_event = gtk_range_scroll_event;
widget_class->key_press_event = gtk_range_key_press;
@@ -667,8 +667,8 @@ gtk_range_init (GtkRange *range)
GTK_WIDGET (range),
gtk_range_measure,
gtk_range_allocate,
- gtk_range_render,
NULL,
+ gtk_range_render,
NULL, NULL);
priv->contents_gadget = gtk_box_gadget_new ("contents",
GTK_WIDGET (range),
@@ -678,8 +678,8 @@ gtk_range_init (GtkRange *range)
NULL, NULL,
gtk_range_measure_trough,
gtk_range_allocate_trough,
- gtk_range_render_trough,
NULL,
+ gtk_range_render_trough,
NULL, NULL);
gtk_css_gadget_set_state (priv->trough_gadget,
gtk_css_node_get_state (widget_node));
@@ -2110,7 +2110,7 @@ gtk_range_state_flags_changed (GtkWidget *widget,
static gboolean
gtk_range_render_trough (GtkCssGadget *gadget,
- cairo_t *cr,
+ GtkSnapshot *snapshot,
int x,
int y,
int width,
@@ -2125,22 +2125,22 @@ gtk_range_render_trough (GtkCssGadget *gadget,
* so we let it...
*/
if (GTK_IS_COLOR_SCALE (widget))
- gtk_color_scale_draw_trough (GTK_COLOR_SCALE (widget), cr, x, y, width, height);
+ gtk_color_scale_snapshot_trough (GTK_COLOR_SCALE (widget), snapshot, x, y, width, height);
if (priv->show_fill_level &&
gtk_adjustment_get_upper (priv->adjustment) - gtk_adjustment_get_page_size (priv->adjustment) -
gtk_adjustment_get_lower (priv->adjustment) != 0)
- gtk_css_gadget_draw (priv->fill_gadget, cr);
+ gtk_css_gadget_snapshot (priv->fill_gadget, snapshot);
if (priv->has_origin)
- gtk_css_gadget_draw (priv->highlight_gadget, cr);
+ gtk_css_gadget_snapshot (priv->highlight_gadget, snapshot);
return gtk_widget_has_visible_focus (widget);
}
static gboolean
gtk_range_render (GtkCssGadget *gadget,
- cairo_t *cr,
+ GtkSnapshot *snapshot,
int x,
int y,
int width,
@@ -2151,24 +2151,22 @@ gtk_range_render (GtkCssGadget *gadget,
GtkRange *range = GTK_RANGE (widget);
GtkRangePrivate *priv = range->priv;
- gtk_css_gadget_draw (priv->contents_gadget, cr);
+ gtk_css_gadget_snapshot (priv->contents_gadget, snapshot);
/* Draw the slider last, so that e.g. the focus ring stays below it */
- gtk_css_gadget_draw (priv->slider_gadget, cr);
+ gtk_css_gadget_snapshot (priv->slider_gadget, snapshot);
return FALSE;
}
-static gboolean
-gtk_range_draw (GtkWidget *widget,
- cairo_t *cr)
+static void
+gtk_range_snapshot (GtkWidget *widget,
+ GtkSnapshot *snapshot)
{
GtkRange *range = GTK_RANGE (widget);
GtkRangePrivate *priv = range->priv;
- gtk_css_gadget_draw (priv->gadget, cr);
-
- return GDK_EVENT_PROPAGATE;
+ gtk_css_gadget_snapshot (priv->gadget, snapshot);
}
static void
diff --git a/gtk/gtkscale.c b/gtk/gtkscale.c
index 82edd96..e332019 100644
--- a/gtk/gtkscale.c
+++ b/gtk/gtkscale.c
@@ -209,8 +209,8 @@ static void gtk_scale_value_style_changed (GtkCssNode *node,
GtkScale *scale);
static void gtk_scale_screen_changed (GtkWidget *widget,
GdkScreen *old_screen);
-static gboolean gtk_scale_draw (GtkWidget *widget,
- cairo_t *cr);
+static void gtk_scale_snapshot (GtkWidget *widget,
+ GtkSnapshot *snapshot);
static void gtk_scale_real_get_layout_offsets (GtkScale *scale,
gint *x,
gint *y);
@@ -717,7 +717,7 @@ gtk_scale_class_init (GtkScaleClass *class)
gobject_class->finalize = gtk_scale_finalize;
widget_class->screen_changed = gtk_scale_screen_changed;
- widget_class->draw = gtk_scale_draw;
+ widget_class->snapshot = gtk_scale_snapshot;
widget_class->size_allocate = gtk_scale_size_allocate;
widget_class->measure = gtk_scale_measure;
@@ -1134,7 +1134,7 @@ gtk_scale_get_digits (GtkScale *scale)
static gboolean
gtk_scale_render_value (GtkCssGadget *gadget,
- cairo_t *cr,
+ GtkSnapshot *snapshot,
int x,
int y,
int width,
@@ -1150,7 +1150,7 @@ gtk_scale_render_value (GtkCssGadget *gadget,
gtk_style_context_save_to_node (context, gtk_css_gadget_get_node (gadget));
layout = gtk_scale_get_layout (scale);
- gtk_render_layout (context, cr, x, y, layout);
+ gtk_snapshot_render_layout (snapshot, context, x, y, layout);
gtk_style_context_restore (context);
@@ -1288,8 +1288,8 @@ gtk_scale_set_draw_value (GtkScale *scale,
widget, NULL, NULL,
gtk_scale_measure_value,
NULL,
- gtk_scale_render_value,
NULL,
+ gtk_scale_render_value,
NULL, NULL);
g_signal_connect (gtk_css_gadget_get_node (priv->value_gadget), "style-changed",
G_CALLBACK (gtk_scale_value_style_changed), scale);
@@ -1741,7 +1741,7 @@ gtk_scale_measure (GtkWidget *widget,
static gboolean
gtk_scale_render_mark_indicator (GtkCssGadget *gadget,
- cairo_t *cr,
+ GtkSnapshot *snapshot,
int x,
int y,
int width,
@@ -1751,19 +1751,23 @@ gtk_scale_render_mark_indicator (GtkCssGadget *gadget,
GtkWidget *widget = gtk_css_gadget_get_owner (gadget);
GtkStyleContext *context;
GtkOrientation orientation;
+ GdkRGBA color;
orientation = gtk_orientable_get_orientation (GTK_ORIENTABLE (widget));
context = gtk_widget_get_style_context (widget);
gtk_style_context_save_to_node (context, gtk_css_gadget_get_node (gadget));
+ gtk_style_context_get_color (context, &color);
if (orientation == GTK_ORIENTATION_HORIZONTAL)
- gtk_render_line (context, cr,
- x + width / 2, y,
- x + width / 2, y + height);
+ gtk_snapshot_append_color_node (snapshot,
+ &color,
+ &GRAPHENE_RECT_INIT(x + width / 2, y, 1, height),
+ "ScaleMark");
else
- gtk_render_line (context, cr,
- x, y + height / 2,
- x + width, y + height / 2);
+ gtk_snapshot_append_color_node (snapshot,
+ &color,
+ &GRAPHENE_RECT_INIT(x, y + height / 2, width, 1),
+ "ScaleMark");
gtk_style_context_restore (context);
@@ -1772,7 +1776,7 @@ gtk_scale_render_mark_indicator (GtkCssGadget *gadget,
static gboolean
gtk_scale_render_mark_label (GtkCssGadget *gadget,
- cairo_t *cr,
+ GtkSnapshot *snapshot,
int x,
int y,
int width,
@@ -1787,7 +1791,7 @@ gtk_scale_render_mark_label (GtkCssGadget *gadget,
gtk_style_context_save_to_node (context, gtk_css_gadget_get_node (gadget));
gtk_css_node_update_layout_attributes (gtk_css_gadget_get_node (gadget), mark->layout);
- gtk_render_layout (context, cr, x, y, mark->layout);
+ gtk_snapshot_render_layout (snapshot, context, x, y, mark->layout);
gtk_style_context_restore (context);
@@ -1796,7 +1800,7 @@ gtk_scale_render_mark_label (GtkCssGadget *gadget,
static gboolean
gtk_scale_render_mark (GtkCssGadget *gadget,
- cairo_t *cr,
+ GtkSnapshot *snapshot,
int x,
int y,
int width,
@@ -1805,16 +1809,16 @@ gtk_scale_render_mark (GtkCssGadget *gadget,
{
GtkScaleMark *mark = user_data;
- gtk_css_gadget_draw (mark->indicator_gadget, cr);
+ gtk_css_gadget_snapshot (mark->indicator_gadget, snapshot);
if (mark->label_gadget)
- gtk_css_gadget_draw (mark->label_gadget, cr);
+ gtk_css_gadget_snapshot (mark->label_gadget, snapshot);
return FALSE;
}
static gboolean
gtk_scale_render_marks (GtkCssGadget *gadget,
- cairo_t *cr,
+ GtkSnapshot *snapshot,
int x,
int y,
int width,
@@ -1834,30 +1838,28 @@ gtk_scale_render_marks (GtkCssGadget *gadget,
(mark->position == GTK_POS_BOTTOM && gadget == priv->top_marks_gadget))
continue;
- gtk_css_gadget_draw (mark->gadget, cr);
+ gtk_css_gadget_snapshot (mark->gadget, snapshot);
}
return FALSE;
}
-static gboolean
-gtk_scale_draw (GtkWidget *widget,
- cairo_t *cr)
+static void
+gtk_scale_snapshot (GtkWidget *widget,
+ GtkSnapshot *snapshot)
{
GtkScale *scale = GTK_SCALE (widget);
GtkScalePrivate *priv = scale->priv;
if (priv->top_marks_gadget)
- gtk_css_gadget_draw (priv->top_marks_gadget, cr);
+ gtk_css_gadget_snapshot (priv->top_marks_gadget, snapshot);
if (priv->bottom_marks_gadget)
- gtk_css_gadget_draw (priv->bottom_marks_gadget, cr);
+ gtk_css_gadget_snapshot (priv->bottom_marks_gadget, snapshot);
- GTK_WIDGET_CLASS (gtk_scale_parent_class)->draw (widget, cr);
+ GTK_WIDGET_CLASS (gtk_scale_parent_class)->snapshot (widget, snapshot);
if (priv->value_gadget)
- gtk_css_gadget_draw (priv->value_gadget, cr);
-
- return FALSE;
+ gtk_css_gadget_snapshot (priv->value_gadget, snapshot);
}
static void
@@ -2165,8 +2167,8 @@ gtk_scale_add_mark (GtkScale *scale,
widget, NULL, NULL,
gtk_scale_measure_marks,
gtk_scale_allocate_marks,
- gtk_scale_render_marks,
NULL,
+ gtk_scale_render_marks,
NULL, NULL);
gtk_css_node_insert_after (widget_node,
gtk_css_gadget_get_node (priv->top_marks_gadget),
@@ -2187,8 +2189,8 @@ gtk_scale_add_mark (GtkScale *scale,
widget, NULL, NULL,
gtk_scale_measure_marks,
gtk_scale_allocate_marks,
- gtk_scale_render_marks,
NULL,
+ gtk_scale_render_marks,
NULL, NULL);
gtk_css_node_insert_before (widget_node,
gtk_css_gadget_get_node (priv->bottom_marks_gadget),
@@ -2206,8 +2208,8 @@ gtk_scale_add_mark (GtkScale *scale,
widget, NULL, NULL,
gtk_scale_measure_mark,
gtk_scale_allocate_mark,
- gtk_scale_render_mark,
NULL,
+ gtk_scale_render_mark,
mark, NULL);
gtk_css_gadget_set_state (mark->gadget, gtk_css_node_get_state (marks_node));
@@ -2216,8 +2218,8 @@ gtk_scale_add_mark (GtkScale *scale,
widget, mark->gadget, NULL,
NULL,
NULL,
- gtk_scale_render_mark_indicator,
NULL,
+ gtk_scale_render_mark_indicator,
mark, NULL);
if (mark->markup && *mark->markup)
{
@@ -2228,8 +2230,8 @@ gtk_scale_add_mark (GtkScale *scale,
NULL : mark->indicator_gadget,
gtk_scale_measure_mark_label,
NULL,
- gtk_scale_render_mark_label,
NULL,
+ gtk_scale_render_mark_label,
mark, NULL);
g_signal_connect (gtk_css_gadget_get_node (mark->label_gadget), "style-changed",
G_CALLBACK (gtk_scale_mark_style_changed), mark);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]