[gtk+] iconview: Implement snapshot()
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+] iconview: Implement snapshot()
- Date: Tue, 20 Dec 2016 17:15:58 +0000 (UTC)
commit c87db76cb5841cbee49364f0ab0cf7592b6722bd
Author: Benjamin Otte <otte redhat com>
Date: Mon Dec 19 17:16:09 2016 +0100
iconview: Implement snapshot()
gtk/gtkiconview.c | 162 ++++++++++++++++++++++++++---------------------------
1 files changed, 80 insertions(+), 82 deletions(-)
---
diff --git a/gtk/gtkiconview.c b/gtk/gtkiconview.c
index 84b77e0..e3690ad 100644
--- a/gtk/gtkiconview.c
+++ b/gtk/gtkiconview.c
@@ -41,6 +41,7 @@
#include "gtkcombobox.h"
#include "gtkscrollable.h"
#include "gtksizerequest.h"
+#include "gtksnapshotprivate.h"
#include "gtktreednd.h"
#include "gtktypebuiltins.h"
#include "gtkprivate.h"
@@ -155,8 +156,8 @@ static void gtk_icon_view_measure (GtkWidget *widget,
int *natural_baseline);
static void gtk_icon_view_size_allocate (GtkWidget *widget,
GtkAllocation *allocation);
-static gboolean gtk_icon_view_draw (GtkWidget *widget,
- cairo_t *cr);
+static void gtk_icon_view_snapshot (GtkWidget *widget,
+ GtkSnapshot *snapshot);
static gboolean gtk_icon_view_motion (GtkWidget *widget,
GdkEventMotion *event);
static gboolean gtk_icon_view_leave (GtkWidget *widget,
@@ -196,14 +197,14 @@ static void gtk_icon_view_set_vadjustment (GtkIco
static void gtk_icon_view_adjustment_changed (GtkAdjustment *adjustment,
GtkIconView *icon_view);
static void gtk_icon_view_layout (GtkIconView *icon_view);
-static void gtk_icon_view_paint_item (GtkIconView *icon_view,
- cairo_t *cr,
+static void gtk_icon_view_snapshot_item (GtkIconView *icon_view,
+ GtkSnapshot *snapshot,
GtkIconViewItem *item,
gint x,
gint y,
gboolean draw_focus);
-static void gtk_icon_view_paint_rubberband (GtkIconView *icon_view,
- cairo_t *cr);
+static void gtk_icon_view_snapshot_rubberband (GtkIconView *icon_view,
+ GtkSnapshot *snapshot);
static void gtk_icon_view_queue_draw_path (GtkIconView *icon_view,
GtkTreePath *path);
static void gtk_icon_view_queue_draw_item (GtkIconView *icon_view,
@@ -358,7 +359,7 @@ gtk_icon_view_class_init (GtkIconViewClass *klass)
widget_class->get_request_mode = gtk_icon_view_get_request_mode;
widget_class->measure = gtk_icon_view_measure;
widget_class->size_allocate = gtk_icon_view_size_allocate;
- widget_class->draw = gtk_icon_view_draw;
+ widget_class->snapshot = gtk_icon_view_snapshot;
widget_class->motion_notify_event = gtk_icon_view_motion;
widget_class->leave_notify_event = gtk_icon_view_leave;
widget_class->button_press_event = gtk_icon_view_button_press;
@@ -1737,9 +1738,9 @@ gtk_icon_view_size_allocate (GtkWidget *widget,
g_object_thaw_notify (G_OBJECT (icon_view->priv->vadjustment));
}
-static gboolean
-gtk_icon_view_draw (GtkWidget *widget,
- cairo_t *cr)
+static void
+gtk_icon_view_snapshot (GtkWidget *widget,
+ GtkSnapshot *snapshot)
{
GtkIconView *icon_view;
GList *icons;
@@ -1752,16 +1753,22 @@ gtk_icon_view_draw (GtkWidget *widget,
icon_view = GTK_ICON_VIEW (widget);
context = gtk_widget_get_style_context (widget);
- gtk_render_background (context, cr,
- 0, 0,
- gtk_widget_get_allocated_width (widget),
- gtk_widget_get_allocated_height (widget));
-
- cairo_save (cr);
-
- gtk_cairo_transform_to_window (cr, widget, icon_view->priv->bin_window);
-
- cairo_set_line_width (cr, 1.);
+ gtk_snapshot_render_background (snapshot, context,
+ 0, 0,
+ gtk_widget_get_allocated_width (widget),
+ gtk_widget_get_allocated_height (widget));
+
+ gtk_snapshot_push_clip (snapshot,
+ &GRAPHENE_RECT_INIT (
+ 0, 0,
+ gtk_widget_get_allocated_width (widget),
+ gtk_widget_get_allocated_height (widget)
+ ),
+ "IconView Clip");
+
+ gtk_snapshot_translate_2d (snapshot,
+ - gtk_adjustment_get_value (icon_view->priv->hadjustment),
+ - gtk_adjustment_get_value (icon_view->priv->vadjustment));
gtk_icon_view_get_drag_dest_item (icon_view, &path, &dest_pos);
@@ -1776,29 +1783,22 @@ gtk_icon_view_draw (GtkWidget *widget,
for (icons = icon_view->priv->items; icons; icons = icons->next)
{
GtkIconViewItem *item = icons->data;
- GdkRectangle paint_area;
-
- paint_area.x = item->cell_area.x - icon_view->priv->item_padding;
- paint_area.y = item->cell_area.y - icon_view->priv->item_padding;
- paint_area.width = item->cell_area.width + icon_view->priv->item_padding * 2;
- paint_area.height = item->cell_area.height + icon_view->priv->item_padding * 2;
-
- cairo_save (cr);
- cairo_rectangle (cr, paint_area.x, paint_area.y, paint_area.width, paint_area.height);
- cairo_clip (cr);
-
- if (gdk_cairo_get_clip_rectangle (cr, NULL))
+ if (!gtk_snapshot_clips_rect (snapshot,
+ &GRAPHENE_RECT_INIT (
+ item->cell_area.x - icon_view->priv->item_padding,
+ item->cell_area.y - icon_view->priv->item_padding,
+ item->cell_area.width + icon_view->priv->item_padding * 2,
+ item->cell_area.height + icon_view->priv->item_padding * 2
+ )))
{
- gtk_icon_view_paint_item (icon_view, cr, item,
- item->cell_area.x, item->cell_area.y,
- icon_view->priv->draw_focus);
+ gtk_icon_view_snapshot_item (icon_view, snapshot, item,
+ item->cell_area.x, item->cell_area.y,
+ icon_view->priv->draw_focus);
if (dest_index == item->index)
dest_item = item;
}
-
- cairo_restore (cr);
}
if (dest_item &&
@@ -1838,17 +1838,17 @@ gtk_icon_view_draw (GtkWidget *widget,
break;
}
- gtk_render_focus (context, cr,
- rect.x, rect.y,
- rect.width, rect.height);
+ gtk_snapshot_render_focus (snapshot, context,
+ rect.x, rect.y,
+ rect.width, rect.height);
}
if (icon_view->priv->doing_rubberband)
- gtk_icon_view_paint_rubberband (icon_view, cr);
+ gtk_icon_view_snapshot_rubberband (icon_view, snapshot);
- cairo_restore (cr);
+ gtk_snapshot_pop_and_append (snapshot);
- return GTK_WIDGET_CLASS (gtk_icon_view_parent_class)->draw (widget, cr);
+ GTK_WIDGET_CLASS (gtk_icon_view_parent_class)->snapshot (widget, snapshot);
}
static gboolean
@@ -2982,12 +2982,12 @@ gtk_icon_view_item_invalidate_size (GtkIconViewItem *item)
}
static void
-gtk_icon_view_paint_item (GtkIconView *icon_view,
- cairo_t *cr,
- GtkIconViewItem *item,
- gint x,
- gint y,
- gboolean draw_focus)
+gtk_icon_view_snapshot_item (GtkIconView *icon_view,
+ GtkSnapshot *snapshot,
+ GtkIconViewItem *item,
+ gint x,
+ gint y,
+ gboolean draw_focus)
{
GdkRectangle cell_area;
GtkStateFlags state = 0;
@@ -3028,16 +3028,16 @@ gtk_icon_view_paint_item (GtkIconView *icon_view,
gtk_style_context_set_state (style_context, state);
- gtk_render_background (style_context, cr,
- x - priv->item_padding,
- y - priv->item_padding,
- item->cell_area.width + priv->item_padding * 2,
- item->cell_area.height + priv->item_padding * 2);
- gtk_render_frame (style_context, cr,
- x - priv->item_padding,
- y - priv->item_padding,
- item->cell_area.width + priv->item_padding * 2,
- item->cell_area.height + priv->item_padding * 2);
+ gtk_snapshot_render_background (snapshot, style_context,
+ x - priv->item_padding,
+ y - priv->item_padding,
+ item->cell_area.width + priv->item_padding * 2,
+ item->cell_area.height + priv->item_padding * 2);
+ gtk_snapshot_render_frame (snapshot, style_context,
+ x - priv->item_padding,
+ y - priv->item_padding,
+ item->cell_area.width + priv->item_padding * 2,
+ item->cell_area.height + priv->item_padding * 2);
cell_area.x = x;
cell_area.y = y;
@@ -3045,23 +3045,21 @@ gtk_icon_view_paint_item (GtkIconView *icon_view,
cell_area.height = item->cell_area.height;
context = g_ptr_array_index (priv->row_contexts, item->row);
- gtk_cell_area_render (priv->cell_area, context,
- widget, cr, &cell_area, &cell_area, flags,
- draw_focus);
+ gtk_cell_area_snapshot (priv->cell_area, context,
+ widget, snapshot, &cell_area, &cell_area, flags,
+ draw_focus);
gtk_style_context_restore (style_context);
}
static void
-gtk_icon_view_paint_rubberband (GtkIconView *icon_view,
- cairo_t *cr)
+gtk_icon_view_snapshot_rubberband (GtkIconView *icon_view,
+ GtkSnapshot *snapshot)
{
GtkIconViewPrivate *priv = icon_view->priv;
GtkStyleContext *context;
GdkRectangle rect;
- cairo_save (cr);
-
rect.x = MIN (priv->rubberband_x1, priv->rubberband_x2);
rect.y = MIN (priv->rubberband_y1, priv->rubberband_y2);
rect.width = ABS (priv->rubberband_x1 - priv->rubberband_x2) + 1;
@@ -3071,18 +3069,14 @@ gtk_icon_view_paint_rubberband (GtkIconView *icon_view,
gtk_style_context_save_to_node (context, priv->rubberband_node);
- gdk_cairo_rectangle (cr, &rect);
- cairo_clip (cr);
-
- gtk_render_background (context, cr,
- rect.x, rect.y,
- rect.width, rect.height);
- gtk_render_frame (context, cr,
- rect.x, rect.y,
- rect.width, rect.height);
+ gtk_snapshot_render_background (snapshot, context,
+ rect.x, rect.y,
+ rect.width, rect.height);
+ gtk_snapshot_render_frame (snapshot, context,
+ rect.x, rect.y,
+ rect.width, rect.height);
gtk_style_context_restore (context);
- cairo_restore (cr);
}
static void
@@ -6984,6 +6978,8 @@ gtk_icon_view_create_drag_icon (GtkIconView *icon_view,
GtkTreePath *path)
{
GtkWidget *widget;
+ GtkSnapshot snapshot;
+ GskRenderNode *node;
cairo_t *cr;
cairo_surface_t *surface;
GList *l;
@@ -7017,13 +7013,15 @@ gtk_icon_view_create_drag_icon (GtkIconView *icon_view,
rect.width,
rect.height);
- cr = cairo_create (surface);
-
- gtk_icon_view_paint_item (icon_view, cr, item,
- icon_view->priv->item_padding,
- icon_view->priv->item_padding,
- FALSE);
+ gtk_snapshot_init (&snapshot, NULL, NULL, "IconView DragIcon");
+ gtk_icon_view_snapshot_item (icon_view, &snapshot, item,
+ icon_view->priv->item_padding,
+ icon_view->priv->item_padding,
+ FALSE);
+ node = gtk_snapshot_finish (&snapshot);
+ cr = cairo_create (surface);
+ gsk_render_node_draw (node, cr);
cairo_destroy (cr);
return surface;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]