void bline_delete_vertex(synfig::ValueNode_Const::Handle value_node);
void bline_insert_vertex(synfig::ValueNode_Const::Handle value_node,float origin=0.5);
void loop_bline();
+ void unloop_bline();
void refresh_ducks(bool x=true);
}
void
+StateBLine_Context::unloop_bline()
+{
+ loop_=false;
+
+ refresh_ducks(false);
+}
+
+void
StateBLine_Context::popup_vertex_menu(synfig::ValueNode_Const::Handle value_node)
{
menu.items().clear();
- if(!loop_ && value_node==bline_point_list.front())
+ if(loop_)
{
+ menu.items().push_back(Gtk::Menu_Helpers::MenuElem("Unloop BLine",
+ sigc::mem_fun(*this,&studio::StateBLine_Context::unloop_bline)
+ ));
+ } else {
menu.items().push_back(Gtk::Menu_Helpers::MenuElem("Loop BLine",
sigc::mem_fun(*this,&studio::StateBLine_Context::loop_bline)
));
{
if(canidate_check(get_param_vocab(),x))
{
- ValueNode::Handle value_node(x.find("value_node")->second.get_value_node());
+ ValueNode::Handle value_node;
+ ValueDesc value_desc(x.find("value_desc")->second.get_value_desc());
+ if(value_desc.parent_is_value_node())
+ value_node = value_desc.get_parent_value_node();
+ else
+ value_node = x.find("value_node")->second.get_value_node();
if(!ValueNode_DynamicList::Handle::cast_dynamic(value_node))
return false;
if(ValueNode_DynamicList::Handle::cast_dynamic(value_node)->get_loop()==true)
bool
Action::ValueNodeDynamicListLoop::set_param(const synfig::String& name, const Action::Param ¶m)
{
- if(name=="value_node" && param.get_type()==Param::TYPE_VALUENODE)
+ if(!value_node && name=="value_desc" && param.get_type()==Param::TYPE_VALUEDESC)
+ {
+ ValueDesc value_desc(param.get_value_desc());
+
+ if(!value_desc.parent_is_value_node())
+ return false;
+
+ value_node=ValueNode_DynamicList::Handle::cast_dynamic(value_desc.get_parent_value_node());
+
+ if (!value_node)
+ return false;
+
+ return true;
+ }
+
+ if(!value_node && name=="value_node" && param.get_type()==Param::TYPE_VALUENODE)
{
value_node=ValueNode_DynamicList::Handle::cast_dynamic(param.get_value_node());
{
if(canidate_check(get_param_vocab(),x))
{
- ValueNode::Handle value_node(x.find("value_node")->second.get_value_node());
+ ValueNode::Handle value_node;
+ ValueDesc value_desc(x.find("value_desc")->second.get_value_desc());
+ if(value_desc.parent_is_value_node())
+ value_node = value_desc.get_parent_value_node();
+ else
+ value_node = x.find("value_node")->second.get_value_node();
if(!ValueNode_DynamicList::Handle::cast_dynamic(value_node))
return false;
if(ValueNode_DynamicList::Handle::cast_dynamic(value_node)->get_loop()==false)
bool
Action::ValueNodeDynamicListUnLoop::set_param(const synfig::String& name, const Action::Param ¶m)
{
- if(name=="value_node" && param.get_type()==Param::TYPE_VALUENODE)
+ if(!value_node && name=="value_desc" && param.get_type()==Param::TYPE_VALUEDESC)
+ {
+ ValueDesc value_desc(param.get_value_desc());
+
+ if(!value_desc.parent_is_value_node())
+ return false;
+
+ value_node=ValueNode_DynamicList::Handle::cast_dynamic(value_desc.get_parent_value_node());
+
+ if (!value_node)
+ return false;
+
+ return true;
+ }
+
+ if(!value_node && name=="value_node" && param.get_type()==Param::TYPE_VALUENODE)
{
value_node=ValueNode_DynamicList::Handle::cast_dynamic(param.get_value_node());