X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftags%2Fstable%2Fsrc%2Fsynfig%2Fvaluenode_blinecalctangent.cpp;fp=synfig-core%2Ftags%2Fstable%2Fsrc%2Fsynfig%2Fvaluenode_blinecalctangent.cpp;h=0000000000000000000000000000000000000000;hb=6fa8f2f38d4b0b35f8539bf94e27ae27015c7689;hp=67c1775aa17691c59b2ac0526d4824ffa3c753fc;hpb=47fce282611fbba1044921d22ca887f9b53ad91a;p=synfig.git diff --git a/synfig-core/tags/stable/src/synfig/valuenode_blinecalctangent.cpp b/synfig-core/tags/stable/src/synfig/valuenode_blinecalctangent.cpp deleted file mode 100644 index 67c1775..0000000 --- a/synfig-core/tags/stable/src/synfig/valuenode_blinecalctangent.cpp +++ /dev/null @@ -1,268 +0,0 @@ -/* === S Y N F I G ========================================================= */ -/*! \file valuenode_blinecalctangent.cpp -** \brief Implementation of the "BLine Tangent" 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 "valuenode_blinecalctangent.h" -#include "valuenode_bline.h" -#include "valuenode_const.h" -#include "valuenode_composite.h" -#include "general.h" -#include "exception.h" -#include -#include - -#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 ======================================================= */ - -ValueNode_BLineCalcTangent::ValueNode_BLineCalcTangent(const ValueBase::Type &x): - LinkableValueNode(x) -{ - if(x!=ValueBase::TYPE_ANGLE && x!=ValueBase::TYPE_REAL && x!=ValueBase::TYPE_VECTOR) - throw Exception::BadType(ValueBase::type_local_name(x)); - - ValueNode_BLine* value_node(new ValueNode_BLine()); - set_link("bline",value_node); - set_link("loop",ValueNode_Const::create(bool(false))); - set_link("amount",ValueNode_Const::create(Real(0.5))); - set_link("offset",ValueNode_Const::create(Angle::deg(0))); - set_link("scale",ValueNode_Const::create(Real(1.0))); - set_link("fixed_length",ValueNode_Const::create(bool(false))); -} - -LinkableValueNode* -ValueNode_BLineCalcTangent::create_new()const -{ - return new ValueNode_BLineCalcTangent(get_type()); -} - -ValueNode_BLineCalcTangent* -ValueNode_BLineCalcTangent::create(const ValueBase &x) -{ - return new ValueNode_BLineCalcTangent(x.get_type()); -} - -ValueNode_BLineCalcTangent::~ValueNode_BLineCalcTangent() -{ - unlink_all(); -} - -ValueBase -ValueNode_BLineCalcTangent::operator()(Time t, Real amount)const -{ - const std::vector bline((*bline_)(t)); - handle bline_value_node(bline_); - const bool looped(bline_value_node->get_loop()); - int size = bline.size(), from_vertex; - bool loop((*loop_)(t).get(bool())); - Angle offset((*offset_)(t).get(Angle())); - Real scale((*scale_)(t).get(Real())); - bool fixed_length((*fixed_length_)(t).get(bool())); - BLinePoint blinepoint0, blinepoint1; - - if (!looped) size--; - if (size < 1) - switch (get_type()) - { - case ValueBase::TYPE_ANGLE: return Angle(); - case ValueBase::TYPE_REAL: return Real(); - case ValueBase::TYPE_VECTOR: return Vector(); - default: assert(0); return ValueBase(); - } - if (loop) - { - amount = amount - int(amount); - if (amount < 0) amount++; - } - else - { - if (amount < 0) amount = 0; - if (amount > 1) amount = 1; - } - - vector::const_iterator iter, next(bline.begin()); - - iter = looped ? --bline.end() : next++; - amount = amount * size; - from_vertex = int(amount); - if (from_vertex > size-1) from_vertex = size-1; - blinepoint0 = from_vertex ? *(next+from_vertex-1) : *iter; - blinepoint1 = *(next+from_vertex); - - etl::hermite curve(blinepoint0.get_vertex(), blinepoint1.get_vertex(), - blinepoint0.get_tangent2(), blinepoint1.get_tangent1()); - etl::derivative< etl::hermite > deriv(curve); - - switch (get_type()) - { - case ValueBase::TYPE_ANGLE: return deriv(amount-from_vertex).angle() + offset; - case ValueBase::TYPE_REAL: - { - if (fixed_length) return scale; - return deriv(amount-from_vertex).mag() * scale; - } - case ValueBase::TYPE_VECTOR: - { - Vector tangent(deriv(amount-from_vertex)); - Angle angle(tangent.angle() + offset); - Real mag = fixed_length ? scale : (tangent.mag() * scale); - return Vector(Angle::cos(angle).get()*mag, - Angle::sin(angle).get()*mag); - } - default: assert(0); return ValueBase(); - } -} - -ValueBase -ValueNode_BLineCalcTangent::operator()(Time t)const -{ - Real amount((*amount_)(t).get(Real())); - return (*this)(t, amount); -} - -String -ValueNode_BLineCalcTangent::get_name()const -{ - return "blinecalctangent"; -} - -String -ValueNode_BLineCalcTangent::get_local_name()const -{ - return _("BLine Tangent"); -} - -bool -ValueNode_BLineCalcTangent::set_link_vfunc(int i,ValueNode::Handle value) -{ - assert(i>=0 && i=0 && i=0 && i=0 && i