X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;ds=sidebyside;f=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Fvaluenode_linear.cpp;h=d4d7bb84414195ae46322109e0d350c51bfaa6aa;hb=334e15ce6c4d9b1f30a168a55e7ef4d31320d568;hp=f0d6c1198a1d52255b72d52d9d14b086e440362d;hpb=37600b4b217caa5e316984ec0b035c5e8f9698af;p=synfig.git diff --git a/synfig-core/trunk/src/synfig/valuenode_linear.cpp b/synfig-core/trunk/src/synfig/valuenode_linear.cpp index f0d6c11..d4d7bb8 100644 --- a/synfig-core/trunk/src/synfig/valuenode_linear.cpp +++ b/synfig-core/trunk/src/synfig/valuenode_linear.cpp @@ -1,6 +1,6 @@ /* === S Y N F I G ========================================================= */ /*! \file valuenode_linear.cpp -** \brief Template File +** \brief Implementation of the "Linear" valuenode conversion. ** ** $Id$ ** @@ -34,6 +34,7 @@ #include "valuenode_const.h" #include "general.h" #include "color.h" +#include #endif @@ -81,7 +82,7 @@ ValueNode_Linear::ValueNode_Linear(const ValueBase &value): set_link("offset",ValueNode_Const::create(value.get(Vector()))); break; default: - throw Exception::BadType(ValueBase::type_name(get_type())); + throw Exception::BadType(ValueBase::type_local_name(get_type())); } DCAST_HACK_ENABLE(); @@ -114,11 +115,7 @@ ValueNode_Linear::operator()(Time t)const case ValueBase::TYPE_COLOR: return (*m_)(t).get( Color())*t+(*b_)(t).get( Color()); case ValueBase::TYPE_INTEGER: - { - Real ret = (*m_)(t).get(int())*t+(*b_)(t).get(int()) + 0.5f; - if (ret < 0) return static_cast(ret-1); - return static_cast(ret); - } + return round_to_int((*m_)(t).get(int())*t+(*b_)(t).get(int())); case ValueBase::TYPE_REAL: return (*m_)(t).get( Real())*t+(*b_)(t).get( Real()); case ValueBase::TYPE_TIME: @@ -158,20 +155,14 @@ ValueNode_Linear::check_type(ValueBase::Type type) } bool -ValueNode_Linear::set_link_vfunc(int i,ValueNode::Handle x) +ValueNode_Linear::set_link_vfunc(int i,ValueNode::Handle value) { - assert(i==0 || i==1); - if(i==0) - { - m_=x; - signal_child_changed()(i);signal_value_changed()(); - return true; - } - if(i==1) + assert(i>=0 && i=0 && i=0 && i=0 && i