summaryrefslogtreecommitdiffstats
path: root/src/sp-fetile.cpp
diff options
context:
space:
mode:
authorFelipe Corr??a da Silva Sanches <juca@members.fsf.org>2007-08-03 22:06:30 +0000
committerjucablues <jucablues@users.sourceforge.net>2007-08-03 22:06:30 +0000
commite001243df1807ee92a27b0c8a3c63484a82e4c83 (patch)
tree050d58021c2745fb656ec877cb0835a32f158a91 /src/sp-fetile.cpp
parentRearrange snapping preferences, put distinction between paths and nodes back ... (diff)
downloadinkscape-e001243df1807ee92a27b0c8a3c63484a82e4c83.tar.gz
inkscape-e001243df1807ee92a27b0c8a3c63484a82e4c83.zip
boiler plate code for feTile
(bzr r3362)
Diffstat (limited to 'src/sp-fetile.cpp')
-rw-r--r--src/sp-fetile.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/src/sp-fetile.cpp b/src/sp-fetile.cpp
index 03967ce05..bb86a4627 100644
--- a/src/sp-fetile.cpp
+++ b/src/sp-fetile.cpp
@@ -33,6 +33,7 @@ static void sp_feTile_release(SPObject *object);
static void sp_feTile_set(SPObject *object, unsigned int key, gchar const *value);
static void sp_feTile_update(SPObject *object, SPCtx *ctx, guint flags);
static Inkscape::XML::Node *sp_feTile_write(SPObject *object, Inkscape::XML::Node *repr, guint flags);
+static void sp_feTile_build_renderer(SPFilterPrimitive *primitive, NR::Filter *filter);
static SPFilterPrimitiveClass *feTile_parent_class;
@@ -61,6 +62,7 @@ static void
sp_feTile_class_init(SPFeTileClass *klass)
{
SPObjectClass *sp_object_class = (SPObjectClass *)klass;
+ SPFilterPrimitiveClass *sp_primitive_class = (SPFilterPrimitiveClass *)klass;
feTile_parent_class = (SPFilterPrimitiveClass*)g_type_class_peek_parent(klass);
@@ -69,6 +71,7 @@ sp_feTile_class_init(SPFeTileClass *klass)
sp_object_class->write = sp_feTile_write;
sp_object_class->set = sp_feTile_set;
sp_object_class->update = sp_feTile_update;
+ sp_primitive_class->build_renderer = sp_feTile_build_renderer;
}
static void
@@ -161,6 +164,19 @@ sp_feTile_write(SPObject *object, Inkscape::XML::Node *repr, guint flags)
return repr;
}
+static void sp_feTile_build_renderer(SPFilterPrimitive *primitive, NR::Filter *filter) {
+ g_assert(primitive != NULL);
+ g_assert(filter != NULL);
+
+ SPFeTile *sp_tile = SP_FETILE(primitive);
+
+ int primitive_n = filter->add_primitive(NR::NR_FILTER_TILE);
+ NR::FilterPrimitive *nr_primitive = filter->get_primitive(primitive_n);
+ NR::FilterTile *nr_tile = dynamic_cast<NR::FilterTile*>(nr_primitive);
+ g_assert(nr_tile != NULL);
+
+ sp_filter_primitive_renderer_common(primitive, nr_primitive);
+}
/*
Local Variables: