1 /* === S Y N F I G ========================================================= */
2 /*! \file blinepointtangentsplit.cpp
3 ** \brief Template File
8 ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
9 ** Copyright (c) 2007 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 /* === H E A D E R S ======================================================= */
33 #include "blinepointtangentsplit.h"
34 #include "valuedescset.h"
36 #include "activepointset.h"
37 #include "activepointadd.h"
39 #include "valuedescconnect.h"
40 #include <synfigapp/canvasinterface.h>
42 #include <synfigapp/general.h>
48 using namespace synfig;
49 using namespace synfigapp;
50 using namespace Action;
52 /* === M A C R O S ========================================================= */
54 ACTION_INIT(Action::BLinePointTangentSplit);
55 ACTION_SET_NAME(Action::BLinePointTangentSplit,"bline_point_tangent_split");
56 ACTION_SET_LOCAL_NAME(Action::BLinePointTangentSplit,N_("Split Tangents"));
57 ACTION_SET_TASK(Action::BLinePointTangentSplit,"split");
58 ACTION_SET_CATEGORY(Action::BLinePointTangentSplit,Action::CATEGORY_VALUENODE);
59 ACTION_SET_PRIORITY(Action::BLinePointTangentSplit,0);
60 ACTION_SET_VERSION(Action::BLinePointTangentSplit,"0.0");
61 ACTION_SET_CVS_ID(Action::BLinePointTangentSplit,"$Id$");
63 /* === G L O B A L S ======================================================= */
65 /* === P R O C E D U R E S ================================================= */
67 /* === M E T H O D S ======================================================= */
69 Action::BLinePointTangentSplit::BLinePointTangentSplit()
71 time=(Time::begin()-1);
76 Action::BLinePointTangentSplit::get_param_vocab()
78 ParamVocab ret(Action::CanvasSpecific::get_param_vocab());
80 ret.push_back(ParamDesc("value_node",Param::TYPE_VALUENODE)
81 .set_local_name(_("ValueNode of BLinePoint"))
84 ret.push_back(ParamDesc("time",Param::TYPE_TIME)
85 .set_local_name(_("Time"))
92 Action::BLinePointTangentSplit::is_candidate(const ParamList &x)
94 if(candidate_check(get_param_vocab(),x))
96 ValueNode_Composite::Handle value_node;
97 value_node=ValueNode_Composite::Handle::cast_dynamic(x.find("value_node")->second.get_value_node());
98 if(!value_node || value_node->get_type()!=ValueBase::TYPE_BLINEPOINT)
100 synfig::Time time(x.find("time")->second.get_time());
101 if((*value_node->get_link("split"))(time).get(bool())==true)
109 Action::BLinePointTangentSplit::set_param(const synfig::String& name, const Action::Param ¶m)
111 if(name=="value_node" && param.get_type()==Param::TYPE_VALUENODE)
113 value_node=value_node.cast_dynamic(param.get_value_node());
115 return (bool)(value_node);
117 if(name=="time" && param.get_type()==Param::TYPE_TIME)
119 time=param.get_time();
124 return Action::CanvasSpecific::set_param(name,param);
128 Action::BLinePointTangentSplit::is_ready()const
131 synfig::error("Missing or bad value_node");
133 if(time==(Time::begin()-1))
134 synfig::error("Missing time");
136 if(!value_node || time==(Time::begin()-1))
138 return Action::CanvasSpecific::is_ready();
142 Action::BLinePointTangentSplit::prepare()
146 Action::Handle action;
148 action=Action::create("value_desc_set");
150 throw Error(_("Couldn't find action \"value_desc_set\""));
152 action->set_param("canvas",get_canvas());
153 action->set_param("canvas_interface",get_canvas_interface());
154 action->set_param("value_desc",ValueDesc(value_node,3));
155 action->set_param("time",time);
156 action->set_param("new_value",synfig::ValueBase(true));
158 assert(action->is_ready());
159 if(!action->is_ready())
160 throw Error(Error::TYPE_NOTREADY);