X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-studio%2Ftrunk%2Fsrc%2Fsynfigapp%2Factions%2Fkeyframeduplicate.cpp;h=faa7741462e34793b626d321b01cfdc037340388;hb=c34eaa5441242b3e9a7b7645e9ee4983d14eae85;hp=425fd645268cd219bd1628fa701363248fbea04a;hpb=02252941b29de64037116f4d37991a38d9ff0d94;p=synfig.git diff --git a/synfig-studio/trunk/src/synfigapp/actions/keyframeduplicate.cpp b/synfig-studio/trunk/src/synfigapp/actions/keyframeduplicate.cpp index 425fd64..faa7741 100644 --- a/synfig-studio/trunk/src/synfigapp/actions/keyframeduplicate.cpp +++ b/synfig-studio/trunk/src/synfigapp/actions/keyframeduplicate.cpp @@ -5,16 +5,17 @@ ** $Id: keyframeduplicate.cpp,v 1.1.1.1 2005/01/07 03:34:37 darco Exp $ ** ** \legal -** Copyright (c) 2002 Robert B. Quattlebaum Jr. +** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley ** -** This software and associated documentation -** are CONFIDENTIAL and PROPRIETARY property of -** the above-mentioned copyright holder. +** This package is free software; you can redistribute it and/or +** modify it under the terms of the GNU General Public License as +** published by the Free Software Foundation; either version 2 of +** the License, or (at your option) any later version. ** -** You may not copy, print, publish, or in any -** other way distribute this software without -** a prior written agreement with -** the copyright holder. +** This package is distributed in the hope that it will be useful, +** but WITHOUT ANY WARRANTY; without even the implied warranty of +** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +** General Public License for more details. ** \endlegal */ /* ========================================================================= */ @@ -71,7 +72,7 @@ Action::ParamVocab Action::KeyframeDuplicate::get_param_vocab() { ParamVocab ret(Action::CanvasSpecific::get_param_vocab()); - + ret.push_back(ParamDesc("keyframe",Param::TYPE_KEYFRAME) .set_local_name(_("Keyframe")) .set_desc(_("Keyframe to be duplicated")) @@ -85,9 +86,9 @@ Action::KeyframeDuplicate::get_param_vocab() } bool -Action::KeyframeDuplicate::is_canidate(const ParamList &x) +Action::KeyframeDuplicate::is_candidate(const ParamList &x) { - return canidate_check(get_param_vocab(),x); + return candidate_check(get_param_vocab(),x); } bool @@ -97,13 +98,13 @@ Action::KeyframeDuplicate::set_param(const synfig::String& name, const Action::P { keyframe=param.get_keyframe(); new_keyframe.set_description(keyframe.get_description()+_(" (Duplicate)")); - + return true; } if(name=="time" && param.get_type()==Param::TYPE_TIME) { new_keyframe.set_time(param.get_time()); - + return true; } @@ -130,12 +131,12 @@ Action::KeyframeDuplicate::prepare() catch(synfig::Exception::NotFound) { throw Error(_("Unable to find the given keyframe")); - } + } try { if(get_canvas()->keyframe_list().find(new_time)!=get_canvas()->keyframe_list().end()) throw Error(_("A Keyframe already exists at this point in time"));} - catch(...) { } + catch(...) { } - // If the times are different, then we + // If the times are different, then we // will need to romp through the valuenodes // and add actions to update their values. if(new_time!=old_time) @@ -152,28 +153,28 @@ Action::KeyframeDuplicate::prepare() void Action::KeyframeDuplicate::process_value_desc(const synfigapp::ValueDesc& value_desc) -{ +{ const synfig::Time old_time=keyframe.get_time(); const synfig::Time new_time=new_keyframe.get_time(); if(value_desc.is_value_node()) { ValueNode::Handle value_node(value_desc.get_value_node()); - + // If we are a dynamic list, then we need to update the ActivePoints if(ValueNode_DynamicList::Handle::cast_dynamic(value_node)) { - ValueNode_DynamicList::Handle value_node(ValueNode_DynamicList::Handle::cast_dynamic(value_node)); + ValueNode_DynamicList::Handle value_node_dynamic(ValueNode_DynamicList::Handle::cast_dynamic(value_node)); int i; - - for(i=0;ilink_count();i++) + + for(i=0;ilink_count();i++) { - synfigapp::ValueDesc value_desc(value_node,i); - Activepoint activepoint(value_node->list[i].new_activepoint_at_time(old_time)); + synfigapp::ValueDesc value_desc(value_node_dynamic,i); + Activepoint activepoint(value_node_dynamic->list[i].new_activepoint_at_time(old_time)); activepoint.set_time(new_time); Action::Handle action(ActivepointSetSmart::create()); - + action->set_param("canvas",get_canvas()); action->set_param("canvas_interface",get_canvas_interface()); action->set_param("value_desc",value_desc); @@ -182,28 +183,28 @@ Action::KeyframeDuplicate::process_value_desc(const synfigapp::ValueDesc& value_ assert(action->is_ready()); if(!action->is_ready()) throw Error(Error::TYPE_NOTREADY); - - add_action_front(action); + + add_action_front(action); } } else if(ValueNode_Animated::Handle::cast_dynamic(value_node)) { - ValueNode_Animated::Handle value_node(ValueNode_Animated::Handle::cast_dynamic(value_node)); - Waypoint waypoint(value_node->new_waypoint_at_time(old_time)); + ValueNode_Animated::Handle value_node_animated(ValueNode_Animated::Handle::cast_dynamic(value_node)); + Waypoint waypoint(value_node_animated->new_waypoint_at_time(old_time)); waypoint.set_time(new_time); - + Action::Handle action(WaypointSetSmart::create()); - + action->set_param("canvas",get_canvas()); action->set_param("canvas_interface",get_canvas_interface()); - action->set_param("value_node",ValueNode::Handle(value_node)); + action->set_param("value_node",ValueNode::Handle(value_node_animated)); action->set_param("waypoint",waypoint); - + assert(action->is_ready()); if(!action->is_ready()) throw Error(Error::TYPE_NOTREADY); - - add_action_front(action); + + add_action_front(action); } } } @@ -212,15 +213,15 @@ void Action::KeyframeDuplicate::perform() { try { get_canvas()->keyframe_list().find(new_keyframe.get_time()); throw Error(_("A Keyframe already exists at this point in time"));} - catch(synfig::Exception::NotFound) { } + catch(synfig::Exception::NotFound) { } try { get_canvas()->keyframe_list().find(new_keyframe); throw Error(_("This keyframe is already in the ValueNode"));} - catch(synfig::Exception::NotFound) { } + catch(synfig::Exception::NotFound) { } Action::Super::perform(); - + get_canvas()->keyframe_list().add(new_keyframe); - + if(get_canvas_interface()) { get_canvas_interface()->signal_keyframe_added()(new_keyframe); @@ -232,12 +233,12 @@ void Action::KeyframeDuplicate::undo() { Action::Super::undo(); - + if(get_canvas_interface()) { get_canvas_interface()->signal_keyframe_removed()(new_keyframe); } else synfig::warning("CanvasInterface not set on action"); - get_canvas()->keyframe_list().erase(new_keyframe); + get_canvas()->keyframe_list().erase(new_keyframe); }