a9c35dcc97b4d10fe4bfa77482a32bb67366ccea
[synfig.git] /
1 /* === S Y N F I G ========================================================= */
2 /*!     \file valuenode_segcalcvertex.h
3 **      \brief Header file for implementation of the "Segment Vertex" valuenode conversion.
4 **
5 **      $Id$
6 **
7 **      \legal
8 **      Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
9 **
10 **      This package is free software; you can redistribute it and/or
11 **      modify it under the terms of the GNU General Public License as
12 **      published by the Free Software Foundation; either version 2 of
13 **      the License, or (at your option) any later version.
14 **
15 **      This package is distributed in the hope that it will be useful,
16 **      but WITHOUT ANY WARRANTY; without even the implied warranty of
17 **      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 **      General Public License for more details.
19 **      \endlegal
20 */
21 /* ========================================================================= */
22
23 /* === S T A R T =========================================================== */
24
25 #ifndef __SYNFIG_VALUENODE_SEGCALCVERTEX_H
26 #define __SYNFIG_VALUENODE_SEGCALCVERTEX_H
27
28 /* === H E A D E R S ======================================================= */
29
30 #include "valuenode.h"
31
32 /* === M A C R O S ========================================================= */
33
34 /* === C L A S S E S & S T R U C T S ======================================= */
35
36 namespace synfig {
37
38 class ValueNode_SegCalcVertex : public LinkableValueNode
39 {
40         ValueNode::RHandle segment_;
41         ValueNode::RHandle amount_;
42
43         ValueNode_SegCalcVertex(const ValueBase::Type &x=ValueBase::TYPE_VECTOR);
44
45 public:
46
47         typedef etl::handle<ValueNode_SegCalcVertex> Handle;
48         typedef etl::handle<const ValueNode_SegCalcVertex> ConstHandle;
49
50 //      static Handle create(const ValueBase::Type &x=ValueBase::TYPE_VECTOR);
51
52
53         virtual ValueBase operator()(Time t)const;
54
55         virtual ~ValueNode_SegCalcVertex();
56
57         virtual String get_name()const;
58         virtual String get_local_name()const;
59 //      static bool check_type(const ValueBase::Type &type);
60
61
62         virtual ValueNode::LooseHandle get_link_vfunc(int i)const;
63         virtual int link_count()const;
64         virtual String link_name(int i)const;
65
66         virtual String link_local_name(int i)const;
67         virtual int get_link_index_from_name(const String &name)const;
68
69 protected:
70         LinkableValueNode* create_new()const;
71         virtual bool set_link_vfunc(int i,ValueNode::Handle x);
72
73 public:
74         using synfig::LinkableValueNode::get_link_vfunc;
75         using synfig::LinkableValueNode::set_link_vfunc;
76         static bool check_type(ValueBase::Type type);
77         static ValueNode_SegCalcVertex* create(const ValueBase &x=ValueBase::TYPE_VECTOR);
78 }; // END of class ValueNode_SegCalcVertex
79
80 }; // END of namespace synfig
81
82 /* === E N D =============================================================== */
83
84 #endif