X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Flayer_composite.cpp;h=d938e9600359297fd31ddbd192f8a57c5f82ac06;hb=6fcfeb5b77c28b403b9fecc9bafcde6834447c9a;hp=7381017d1c8bbff65af557c63f80243a16180784;hpb=0d270efd0dd73dad0077a76ab0b5408510ab1151;p=synfig.git diff --git a/synfig-core/trunk/src/synfig/layer_composite.cpp b/synfig-core/trunk/src/synfig/layer_composite.cpp index 7381017..d938e96 100644 --- a/synfig-core/trunk/src/synfig/layer_composite.cpp +++ b/synfig-core/trunk/src/synfig/layer_composite.cpp @@ -155,16 +155,41 @@ Layer_Composite::set_param(const String & param, const ValueBase &value) else if(param=="blend_method" && value.same_type_as(int())) { - Color::BlendMethod blend_method = static_cast(value.get(int())); + blend_method_ = static_cast(value.get(int())); - if (blend_method < 0 || blend_method >= Color::BLEND_END) + if (blend_method_ < 0 || blend_method_ >= Color::BLEND_END) { - warning("illegal value (%d) for blend_method - using Composite instead", blend_method); + warning("illegal value (%d) for blend_method - using Composite instead", blend_method_); blend_method_ = Color::BLEND_COMPOSITE; return false; } - blend_method_ = blend_method; + if (blend_method_ == Color::BLEND_STRAIGHT && !reads_context()) + { + Canvas::Handle canvas(get_canvas()); + if (canvas) + { + String version(canvas->get_version()); + + if (version == "0.1" || version == "0.2") + { + if (get_name() == "PasteCanvas") + warning("loaded a version %s canvas with a 'Straight' blended PasteCanvas (%s) - check it renders OK", + version.c_str(), get_non_empty_description().c_str()); + else + { + blend_method_ = Color::BLEND_COMPOSITE; + converted_blend_ = true; + + // if this layer has a transparent color, go back and set the color again + // now that we know we are converting the blend method as well. that will + // make the color non-transparent, and change the blend method to alpha over + if (transparent_color_) + set_param("color", get_param("color")); + } + } + } + } } else return Layer::set_param(param,value);