X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Fvaluenode_linear.cpp;h=9c1788f8eb5dcafa9055ac57535ce61fdf737f91;hb=e802271c263e2a49ab4edb3660f89c27e642d123;hp=df8205798cee0fb300dc09b68143eb8cfcd432f7;hpb=24a04c6ee533b747f8ff6b128c86c6a01f390a88;p=synfig.git diff --git a/synfig-core/trunk/src/synfig/valuenode_linear.cpp b/synfig-core/trunk/src/synfig/valuenode_linear.cpp index df82057..9c1788f 100644 --- a/synfig-core/trunk/src/synfig/valuenode_linear.cpp +++ b/synfig-core/trunk/src/synfig/valuenode_linear.cpp @@ -86,6 +86,12 @@ ValueNode_Linear::ValueNode_Linear(const ValueBase &value): DCAST_HACK_ENABLE(); } +LinkableValueNode* +ValueNode_Linear::create_new()const +{ + return new ValueNode_Linear(get_type()); +} + ValueNode_Linear* ValueNode_Linear::create(const ValueBase &x) { @@ -107,7 +113,11 @@ ValueNode_Linear::operator()(Time t)const case ValueBase::TYPE_COLOR: return (*m_)(t).get( Color())*t+(*b_)(t).get( Color()); case ValueBase::TYPE_INTEGER: - return static_cast((*m_)(t).get(int())*t+(*b_)(t).get(int()) + 0.5f); + { + 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); + } case ValueBase::TYPE_REAL: return (*m_)(t).get( Real())*t+(*b_)(t).get( Real()); case ValueBase::TYPE_TIME: @@ -219,9 +229,3 @@ ValueNode_Linear::get_link_index_from_name(const String &name)const throw Exception::BadLinkName(name); } - -LinkableValueNode* -ValueNode_Linear::create_new()const -{ - return new ValueNode_Linear(get_type()); -}