Remove .gitignore do nothing is ignored.
[synfig.git] / synfig-studio / trunk / src / synfigapp / actions / colorset.cpp
index 42c23ce..93e7c76 100644 (file)
@@ -38,6 +38,8 @@
 #include <synfigapp/canvasinterface.h>
 #include <synfigapp/main.h>
 
+#include <synfigapp/general.h>
+
 #endif
 
 using namespace std;
@@ -48,14 +50,23 @@ using namespace Action;
 
 /* === M A C R O S ========================================================= */
 
-ACTION_INIT(Action::ColorSet);
-ACTION_SET_NAME(Action::ColorSet,"color_set");
-ACTION_SET_LOCAL_NAME(Action::ColorSet,"Apply Default Color");
-ACTION_SET_TASK(Action::ColorSet,"set");
-ACTION_SET_CATEGORY(Action::ColorSet,Action::CATEGORY_VALUEDESC);
-ACTION_SET_PRIORITY(Action::ColorSet,0);
-ACTION_SET_VERSION(Action::ColorSet,"0.0");
-ACTION_SET_CVS_ID(Action::ColorSet,"$Id$");
+ACTION_INIT(Action::ColorSetFromOC);
+ACTION_SET_NAME(Action::ColorSetFromOC, "ColorSetFromOC");
+ACTION_SET_LOCAL_NAME(Action::ColorSetFromOC, N_("Apply Outline Color"));
+ACTION_SET_TASK(Action::ColorSetFromOC, "set");
+ACTION_SET_CATEGORY(Action::ColorSetFromOC, Action::CATEGORY_VALUEDESC);
+ACTION_SET_PRIORITY(Action::ColorSetFromOC, 0);
+ACTION_SET_VERSION(Action::ColorSetFromOC, "0.0");
+ACTION_SET_CVS_ID(Action::ColorSetFromOC, "$Id$");
+
+ACTION_INIT(Action::ColorSetFromFC);
+ACTION_SET_NAME(Action::ColorSetFromFC, "ColorSetFromFC");
+ACTION_SET_LOCAL_NAME(Action::ColorSetFromFC, N_("Apply Fill Color"));
+ACTION_SET_TASK(Action::ColorSetFromFC, "set");
+ACTION_SET_CATEGORY(Action::ColorSetFromFC, Action::CATEGORY_VALUEDESC);
+ACTION_SET_PRIORITY(Action::ColorSetFromFC, 0);
+ACTION_SET_VERSION(Action::ColorSetFromFC, "0.0");
+ACTION_SET_CVS_ID(Action::ColorSetFromFC, "$Id$");
 
 /* === G L O B A L S ======================================================= */
 
@@ -63,8 +74,8 @@ ACTION_SET_CVS_ID(Action::ColorSet,"$Id$");
 
 /* === M E T H O D S ======================================================= */
 
-Action::ColorSet::ColorSet():
-       time(0)
+Action::ColorSet::ColorSet(bool use_outline_color):
+  time(0), use_outline_color(use_outline_color)
 {
 }
 
@@ -75,6 +86,7 @@ Action::ColorSet::get_param_vocab()
 
        ret.push_back(ParamDesc("value_desc",Param::TYPE_VALUEDESC)
                .set_local_name(_("ValueDesc"))
+               .set_supports_multiple()
        );
 
        ret.push_back(ParamDesc("time",Param::TYPE_TIME)
@@ -88,40 +100,57 @@ Action::ColorSet::get_param_vocab()
 bool
 Action::ColorSet::is_candidate(const ParamList &x)
 {
-       if(!candidate_check(get_param_vocab(),x))
+       if (!candidate_check(get_param_vocab(), x))
                return false;
-       return x.find("value_desc")->second.get_value_desc().get_value_type()==ValueBase::TYPE_COLOR;
+
+       std::multimap<synfig::String, Param>::const_iterator iter;
+       for (iter = x.begin(); iter != x.end(); ++iter)
+       {
+               if (iter->first == "value_desc" &&
+                               iter->second.get_value_desc().get_value_type() != ValueBase::TYPE_COLOR)
+                       return false;
+       }
+
+       return true;
 }
 
 bool
 Action::ColorSet::set_param(const synfig::String& name, const Action::Param &param)
 {
-       if(name=="value_desc" && param.get_type()==Param::TYPE_VALUEDESC)
+       if (name == "value_desc" && param.get_type() == Param::TYPE_VALUEDESC)
        {
                // Grab the value_desc
-               value_desc=param.get_value_desc();
+               ValueDesc value_desc = param.get_value_desc();
+               if (value_desc.get_value_type() != ValueBase::TYPE_COLOR)
+                       return false;
 
-               // Grab the current color
-               color=synfigapp::Main::get_foreground_color();
+               value_desc_list.push_back(value_desc);
 
-               return value_desc.get_value_type()==ValueBase::TYPE_COLOR;
+               // Grab the current outline or fill color
+               if (use_outline_color)
+                       color = synfigapp::Main::get_outline_color();
+               else
+                       color = synfigapp::Main::get_fill_color();
+
+               return true;
        }
 
-       if(name=="time" && param.get_type()==Param::TYPE_TIME)
+       if (name == "time" && param.get_type() == Param::TYPE_TIME)
        {
-               time=param.get_time();
+               time = param.get_time();
 
                return true;
        }
 
-       return Action::CanvasSpecific::set_param(name,param);
+       return Action::CanvasSpecific::set_param(name, param);
 }
 
 bool
-Action::ColorSet::is_ready()const
+Action::ColorSet::is_ready() const
 {
-       if(!value_desc || value_desc.get_value_type()!=ValueBase::TYPE_COLOR)
+       if (value_desc_list.size() == 0)
                return false;
+
        return Action::CanvasSpecific::is_ready();
 }
 
@@ -130,17 +159,21 @@ Action::ColorSet::prepare()
 {
        clear();
 
-       Action::Handle action;
-       action=Action::create("value_desc_set");
+       std::list<ValueDesc>::iterator iter;
+       for (iter = value_desc_list.begin(); iter != value_desc_list.end(); ++iter)
+       {
+               ValueDesc& value_desc(*iter);
 
-       action->set_param("canvas",get_canvas());
-       action->set_param("canvas_interface",get_canvas_interface());
-       action->set_param("value_desc",value_desc);
-       action->set_param("new_value",ValueBase(color));
-       action->set_param("time",time);
+               Action::Handle action = Action::create("ValueDescSet");
+               action->set_param("canvas", get_canvas());
+               action->set_param("canvas_interface", get_canvas_interface());
+               action->set_param("value_desc", value_desc);
+               action->set_param("new_value", ValueBase(color));
+               action->set_param("time", time);
 
-       if(!action->is_ready())
-               throw Error(Error::TYPE_NOTREADY);
+               if (!action->is_ready())
+                       throw Error(Error::TYPE_NOTREADY);
 
-       add_action_front(action);
+               add_action_front(action);
+       }
 }