diff options
| author | Felipe Corr??a da Silva Sanches <juca@members.fsf.org> | 2007-08-03 22:06:30 +0000 |
|---|---|---|
| committer | jucablues <jucablues@users.sourceforge.net> | 2007-08-03 22:06:30 +0000 |
| commit | e001243df1807ee92a27b0c8a3c63484a82e4c83 (patch) | |
| tree | 050d58021c2745fb656ec877cb0835a32f158a91 /src/sp-fetile.cpp | |
| parent | Rearrange snapping preferences, put distinction between paths and nodes back ... (diff) | |
| download | inkscape-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.cpp | 16 |
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: |
