1 /* === S Y N F I G ========================================================= */
2 /*! \file valuenode_blinecalctangent.h
3 ** \brief Header file for implementation of the "BLine Tangent" valuenode conversion.
8 ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
9 ** Copyright (c) 2008 Chris Moore
11 ** This package is free software; you can redistribute it and/or
12 ** modify it under the terms of the GNU General Public License as
13 ** published by the Free Software Foundation; either version 2 of
14 ** the License, or (at your option) any later version.
16 ** This package is distributed in the hope that it will be useful,
17 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
18 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19 ** General Public License for more details.
22 /* ========================================================================= */
24 /* === S T A R T =========================================================== */
26 #ifndef __SYNFIG_VALUENODE_BLINECALCTANGENT_H
27 #define __SYNFIG_VALUENODE_BLINECALCTANGENT_H
29 /* === H E A D E R S ======================================================= */
31 #include "valuenode.h"
33 /* === M A C R O S ========================================================= */
35 /* === C L A S S E S & S T R U C T S ======================================= */
39 class ValueNode_BLineCalcTangent : public LinkableValueNode
41 ValueNode::RHandle bline_;
42 ValueNode::RHandle loop_;
43 ValueNode::RHandle amount_;
44 ValueNode::RHandle offset_;
45 ValueNode::RHandle scale_;
46 ValueNode::RHandle fixed_length_;
48 ValueNode_BLineCalcTangent(const ValueBase::Type &x=ValueBase::TYPE_VECTOR);
52 typedef etl::handle<ValueNode_BLineCalcTangent> Handle;
53 typedef etl::handle<const ValueNode_BLineCalcTangent> ConstHandle;
55 virtual ValueBase operator()(Time t, Real amount)const;
56 virtual ValueBase operator()(Time t)const;
58 virtual ~ValueNode_BLineCalcTangent();
60 virtual String get_name()const;
61 virtual String get_local_name()const;
63 virtual ValueNode::LooseHandle get_link_vfunc(int i)const;
64 virtual int link_count()const;
65 virtual String link_name(int i)const;
67 virtual String link_local_name(int i)const;
68 virtual int get_link_index_from_name(const String &name)const;
71 virtual bool set_link_vfunc(int i,ValueNode::Handle x);
72 LinkableValueNode* create_new()const;
75 using synfig::LinkableValueNode::get_link_vfunc;
76 using synfig::LinkableValueNode::set_link_vfunc;
77 static bool check_type(ValueBase::Type type);
78 static ValueNode_BLineCalcTangent* create(const ValueBase &x=ValueBase::TYPE_VECTOR);
79 }; // END of class ValueNode_BLineCalcTangent
81 }; // END of namespace synfig
83 /* === E N D =============================================================== */