X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-studio%2Ftrunk%2Fsrc%2Fsynfigapp%2Fvalue_desc.h;h=ccc562a101a3d7fd46218c8745bdc12fe6e77844;hb=b0ac74b597f00a1f222d7627e6ff760feb07bff7;hp=841b40ecfafac234a98582ebfa59596fe5b1cf82;hpb=1399c4c168f10ce3608213eba66f44daaf41606a;p=synfig.git diff --git a/synfig-studio/trunk/src/synfigapp/value_desc.h b/synfig-studio/trunk/src/synfigapp/value_desc.h index 841b40e..ccc562a 100644 --- a/synfig-studio/trunk/src/synfigapp/value_desc.h +++ b/synfig-studio/trunk/src/synfigapp/value_desc.h @@ -32,6 +32,7 @@ #include #include #include +#include #include #include @@ -51,7 +52,8 @@ class ValueDesc // Info for ValueNode parent synfig::ValueNode::Handle parent_value_node; - int index; + int index; // -2 if it's a waypoint, -1 if it's const, >=0 if it's LinkableValueNode + synfig::Time waypoint_time; // Info for exported ValueNode synfig::Canvas::Handle canvas; @@ -69,7 +71,7 @@ public: return false; if((parent_value_node||rhs.parent_value_node) && parent_value_node!=rhs.parent_value_node) return false; - if((index>-1||rhs.index>-1) && index!=rhs.index) + if(index!=rhs.index) return false; return true; } @@ -95,6 +97,11 @@ public: // parent_value_node(parent_value_node), // index(parent_value_node->get_link_index_from_name(param_name)) { } + ValueDesc(synfig::ValueNode_Animated::Handle parent_value_node,synfig::Time waypoint_time): + parent_value_node(parent_value_node), + index(-2), + waypoint_time(waypoint_time) { } + ValueDesc(synfig::Canvas::Handle canvas,const synfig::String& name): name(name), canvas(canvas) { } @@ -112,6 +119,7 @@ public: bool parent_is_value_node()const { return (bool)parent_value_node; } bool parent_is_linkable_value_node()const { return parent_is_value_node() && index>=0; } bool parent_is_value_node_const()const { return parent_is_value_node() && index==-1; } + bool parent_is_waypoint()const { return parent_is_value_node() && index==-2; } bool parent_is_canvas()const { return (bool)canvas; } bool is_value_node()const { return parent_is_value_node() || parent_is_canvas() || (parent_is_layer_param() && (bool)layer->dynamic_param_list().count(name)); } @@ -122,6 +130,7 @@ public: synfig::ValueNode::Handle get_parent_value_node()const { assert(parent_is_value_node()); return parent_value_node; } int get_index()const { assert(parent_is_linkable_value_node()); return index; } + synfig::Time get_waypoint_time()const { assert(parent_is_waypoint()); return waypoint_time; } const synfig::String& get_value_node_id()const { assert(parent_is_canvas()); return name; } @@ -148,6 +157,8 @@ public: // return reinterpret_cast(parent_value_node.get())->get_link(index); if(parent_is_value_node_const()) return parent_value_node; + if(parent_is_waypoint()) + return (synfig::ValueNode_Animated::Handle::cast_reinterpret(parent_value_node))->find(waypoint_time)->get_value_node(); return 0; }