X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Fvaluenode_linear.cpp;h=d487b7bf91adc53414818df588767b877d6cbc83;hb=6c27d1b6cf4694a873542cb264c650893f2c6e0e;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..d487b7b 100644 --- a/synfig-core/trunk/src/synfig/valuenode_linear.cpp +++ b/synfig-core/trunk/src/synfig/valuenode_linear.cpp @@ -1,11 +1,12 @@ /* === S Y N F I G ========================================================= */ /*! \file valuenode_linear.cpp -** \brief Template File +** \brief Implementation of the "Linear" valuenode conversion. ** ** $Id$ ** ** \legal ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley +** Copyright (c) 2007 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 @@ -33,6 +34,7 @@ #include "valuenode_const.h" #include "general.h" #include "color.h" +#include #endif @@ -80,12 +82,18 @@ 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(); } +LinkableValueNode* +ValueNode_Linear::create_new()const +{ + return new ValueNode_Linear(get_type()); +} + ValueNode_Linear* ValueNode_Linear::create(const ValueBase &x) { @@ -107,7 +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: - return static_cast((*m_)(t).get(int())*t+(*b_)(t).get(int()) + 0.5f); + 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: @@ -149,7 +157,8 @@ ValueNode_Linear::check_type(ValueBase::Type type) bool ValueNode_Linear::set_link_vfunc(int i,ValueNode::Handle x) { - assert(i==0 || i==1); + assert(i>=0 && i=0 && i=0 && i=0 && i