X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Fsrc%2Fsynfig%2Fvaluenode_repeat_gradient.cpp;fp=synfig-core%2Fsrc%2Fsynfig%2Fvaluenode_repeat_gradient.cpp;h=c9ad14ace50b285bac82547897ec59080ec023e7;hb=a095981e18cc37a8ecc7cd237cc22b9c10329264;hp=0000000000000000000000000000000000000000;hpb=9459638ad6797b8139f1e9f0715c96076dbf0890;p=synfig.git diff --git a/synfig-core/src/synfig/valuenode_repeat_gradient.cpp b/synfig-core/src/synfig/valuenode_repeat_gradient.cpp new file mode 100644 index 0000000..c9ad14a --- /dev/null +++ b/synfig-core/src/synfig/valuenode_repeat_gradient.cpp @@ -0,0 +1,244 @@ +/* === S Y N F I G ========================================================= */ +/*! \file valuenode_repeat_gradient.cpp +** \brief Implementation of the "Repeat Gradient" valuenode conversion. +** +** $Id$ +** +** \legal +** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley +** Copyright (c) 2007, 2008 Chris Moore +** +** This package is free software; you can redistribute it and/or +** modify it under the terms of the GNU General Public License as +** published by the Free Software Foundation; either version 2 of +** the License, or (at your option) any later version. +** +** This package is distributed in the hope that it will be useful, +** but WITHOUT ANY WARRANTY; without even the implied warranty of +** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +** General Public License for more details. +** \endlegal +*/ +/* ========================================================================= */ + +/* === H E A D E R S ======================================================= */ + +#ifdef USING_PCH +# include "pch.h" +#else +#ifdef HAVE_CONFIG_H +# include +#endif + +#include "general.h" +#include "valuenode_repeat_gradient.h" +#include "valuenode_const.h" +#include +#include "color.h" +#include "gradient.h" + +#endif + +/* === U S I N G =========================================================== */ + +using namespace std; +using namespace etl; +using namespace synfig; + +/* === M A C R O S ========================================================= */ + +/* === G L O B A L S ======================================================= */ + +/* === P R O C E D U R E S ================================================= */ + +/* === M E T H O D S ======================================================= */ + +synfig::ValueNode_Repeat_Gradient::ValueNode_Repeat_Gradient(const Gradient& x):LinkableValueNode(synfig::ValueBase::TYPE_GRADIENT) +{ + set_link("gradient",ValueNode_Const::create(x)); + set_link("count",count_=ValueNode_Const::create(int(3))); + set_link("width",ValueNode_Const::create(0.5)); + set_link("specify_start",ValueNode_Const::create(true)); + set_link("specify_end",ValueNode_Const::create(true)); + set_link("start_color",ValueNode_Const::create(Color::alpha())); + set_link("end_color",ValueNode_Const::create(Color::alpha())); +} + +LinkableValueNode* +ValueNode_Repeat_Gradient::create_new()const +{ + return new ValueNode_Repeat_Gradient(Gradient()); +} + +ValueNode_Repeat_Gradient* +ValueNode_Repeat_Gradient::create(const ValueBase& x) +{ + ValueBase::Type id(x.get_type()); + + if(id!=ValueBase::TYPE_GRADIENT) + { + assert(0); + throw runtime_error(String(_("Repeat Gradient"))+_(":Bad type ")+ValueBase::type_local_name(id)); + } + + ValueNode_Repeat_Gradient* value_node=new ValueNode_Repeat_Gradient(x.get(Gradient())); + + assert(value_node->get_type()==id); + + return value_node; +} + +synfig::ValueNode_Repeat_Gradient::~ValueNode_Repeat_Gradient() +{ + unlink_all(); +} + +synfig::ValueBase +synfig::ValueNode_Repeat_Gradient::operator()(Time t)const +{ + if (getenv("SYNFIG_DEBUG_VALUENODE_OPERATORS")) + printf("%s:%d operator()\n", __FILE__, __LINE__); + + const int count((*count_)(t).get(int())); + int i; + Gradient ret; + + if(count<=0) + return ret; + + const Gradient gradient((*gradient_)(t).get(Gradient())); + const float width(max(0.0,min(1.0,(*width_)(t).get(Real())))); + const bool specify_start((*specify_start_)(t).get(bool())); + const bool specify_end((*specify_end_)(t).get(bool())); + + const float gradient_width_a(width/count); + const float gradient_width_b((1.0-width)/count); + + Gradient::const_iterator iter; + Gradient::const_reverse_iterator riter; + if (specify_start) + ret.push_back(Gradient::CPoint(0,(*start_color_)(t).get(Color()))); + for(i=0;ipos,iter->color)); + pos+=gradient_width_a; + if (width != 1.0) + for(riter=gradient.rbegin();riter!=gradient.rend();riter++) + ret.push_back(Gradient::CPoint(pos+gradient_width_b*(1-(riter->pos)),riter->color)); + } + if (specify_end) + ret.push_back(Gradient::CPoint(1,(*end_color_)(t).get(Color()))); + return ret; +} + +bool +ValueNode_Repeat_Gradient::set_link_vfunc(int i,ValueNode::Handle value) +{ + assert(i>=0 && i=0 && i=0 && i=0 && i