summaryrefslogtreecommitdiffstats
path: root/src/sp-feblend.cpp
diff options
context:
space:
mode:
authorNiko Kiirala <niko@kiirala.com>2007-05-29 10:47:04 +0000
committerkiirala <kiirala@users.sourceforge.net>2007-05-29 10:47:04 +0000
commitbb8c80451efac613442f77de66d246065ffa4fcf (patch)
tree61128cfdaedcc105fd1cb0861e0583a9cee47690 /src/sp-feblend.cpp
parentAdd auto gap filling for Paint Bucket and implement "safety valve" to prevent... (diff)
downloadinkscape-bb8c80451efac613442f77de66d246065ffa4fcf.tar.gz
inkscape-bb8c80451efac613442f77de66d246065ffa4fcf.zip
Added support for in-parameter in filter primitives
(bzr r3041)
Diffstat (limited to 'src/sp-feblend.cpp')
-rw-r--r--src/sp-feblend.cpp28
1 files changed, 16 insertions, 12 deletions
diff --git a/src/sp-feblend.cpp b/src/sp-feblend.cpp
index 49ab18a25..bedbf4f61 100644
--- a/src/sp-feblend.cpp
+++ b/src/sp-feblend.cpp
@@ -43,7 +43,6 @@ static Inkscape::XML::Node *sp_feBlend_write(SPObject *object, Inkscape::XML::No
static void sp_feBlend_build_renderer(SPFilterPrimitive *sp_prim, NR::Filter *filter);
static SPFilterPrimitiveClass *feBlend_parent_class;
-static int renderer;
GType
sp_feBlend_get_type()
@@ -86,7 +85,7 @@ sp_feBlend_class_init(SPFeBlendClass *klass)
static void
sp_feBlend_init(SPFeBlend *feBlend)
{
- renderer = -1;
+ feBlend->in2 = NR::NR_FILTER_SLOT_NOT_SET;
}
/**
@@ -103,6 +102,7 @@ sp_feBlend_build(SPObject *object, SPDocument *document, Inkscape::XML::Node *re
/*LOAD ATTRIBUTES FROM REPR HERE*/
sp_object_read_attr(object, "mode");
+ sp_object_read_attr(object, "in2");
}
/**
@@ -155,18 +155,23 @@ sp_feBlend_set(SPObject *object, unsigned int key, gchar const *value)
SPFeBlend *feBlend = SP_FEBLEND(object);
(void)feBlend;
+ NR::FilterBlendMode mode;
+ int input;
switch(key) {
/*DEAL WITH SETTING ATTRIBUTES HERE*/
case SP_ATTR_MODE:
- feBlend->blend_mode = sp_feBlend_readmode(value);
-/*
- if (renderer >= 0) {
- NR::Filter *filter = SP_FILTER(object->parent)->_renderer;
- NR::FilterBlend *blend = dynamic_cast<NR::FilterBlend*>(filter->get_primitive(renderer));
- blend->set_mode(feBlend->blend_mode);
+ mode = sp_feBlend_readmode(value);
+ if (mode != feBlend->blend_mode) {
+ feBlend->blend_mode = mode;
+ object->parent->requestModified(SP_OBJECT_MODIFIED_FLAG);
+ }
+ break;
+ case SP_ATTR_IN2:
+ input = sp_filter_primitive_read_in(feBlend, value);
+ if (input != feBlend->in2) {
+ feBlend->in2 = input;
+ object->parent->requestModified(SP_OBJECT_MODIFIED_FLAG);
}
-*/
- object->parent->requestModified(SP_OBJECT_MODIFIED_FLAG);
break;
default:
if (((SPObjectClass *) feBlend_parent_class)->set)
@@ -228,8 +233,7 @@ static void sp_feBlend_build_renderer(SPFilterPrimitive *primitive, NR::Filter *
sp_filter_primitive_renderer_common(primitive, nr_primitive);
nr_blend->set_mode(sp_blend->blend_mode);
-
- renderer = primitive_n;
+ nr_blend->set_input(1, sp_blend->in2);
}
/*