X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftags%2Fstable%2Fsrc%2Fmodules%2Fmod_geometry%2Fstar.cpp;h=cb1d8e6efe678963aa4522cb2a39508fc3176804;hb=47fce282611fbba1044921d22ca887f9b53ad91a;hp=4dfc3581de1eec727e03418633322cc367285402;hpb=d3408370fc3297609b3aa8d4ff7edf1f238df251;p=synfig.git diff --git a/synfig-core/tags/stable/src/modules/mod_geometry/star.cpp b/synfig-core/tags/stable/src/modules/mod_geometry/star.cpp index 4dfc358..cb1d8e6 100644 --- a/synfig-core/tags/stable/src/modules/mod_geometry/star.cpp +++ b/synfig-core/tags/stable/src/modules/mod_geometry/star.cpp @@ -1,11 +1,12 @@ /* === S Y N F I G ========================================================= */ /*! \file star.cpp -** \brief Template Header +** \brief Implementation of the "Star" layer ** ** $Id$ ** ** \legal ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley +** Copyright (c) 2007-2008 Chris Moore ** ** This package is free software; you can redistribute it and/or ** modify it under the terms of the GNU General Public License as @@ -58,8 +59,8 @@ using namespace etl; SYNFIG_LAYER_INIT(Star); SYNFIG_LAYER_SET_NAME(Star,"star"); -SYNFIG_LAYER_SET_LOCAL_NAME(Star,_("Star")); -SYNFIG_LAYER_SET_CATEGORY(Star,_("Geometry")); +SYNFIG_LAYER_SET_LOCAL_NAME(Star,N_("Star")); +SYNFIG_LAYER_SET_CATEGORY(Star,N_("Geometry")); SYNFIG_LAYER_SET_VERSION(Star,"0.1"); SYNFIG_LAYER_SET_CVS_ID(Star,"$Id$"); @@ -73,7 +74,8 @@ Star::Star(): radius1(1.0), radius2(0.38), points(5), - angle(Angle::deg(90)) + angle(Angle::deg(90)), + regular_polygon(false) { sync(); } @@ -90,7 +92,8 @@ Star::sync() Angle dist1(dist_between_points*i+angle); Angle dist2(dist_between_points*i+dist_between_points/2+angle); vector_list.push_back(Point(Angle::cos(dist1).get()*radius1,Angle::sin(dist1).get()*radius1)); - vector_list.push_back(Point(Angle::cos(dist2).get()*radius2,Angle::sin(dist2).get()*radius2)); + if (!regular_polygon) + vector_list.push_back(Point(Angle::cos(dist2).get()*radius2,Angle::sin(dist2).get()*radius2)); } clear(); add_polygon(vector_list); @@ -99,21 +102,21 @@ Star::sync() bool Star::set_param(const String & param, const ValueBase &value) { - if( param=="radius1" && value.same_as(radius1)) + if( param=="radius1" && value.same_type_as(radius1)) { value.put(&radius1); sync(); return true; } - if( param=="radius2" && value.same_as(radius2)) + if( param=="radius2" && value.same_type_as(radius2)) { value.put(&radius2); sync(); return true; } - if( param=="points" && value.same_as(points)) + if( param=="points" && value.same_type_as(points)) { value.put(&points); if(points<2)points=2; @@ -121,13 +124,20 @@ Star::set_param(const String & param, const ValueBase &value) return true; } - if( param=="angle" && value.same_as(angle)) + if( param=="angle" && value.same_type_as(angle)) { value.put(&angle); sync(); return true; } + if(param=="regular_polygon" && value.same_type_as(regular_polygon)) + { + value.put(®ular_polygon); + sync(); + return true; + } + if(param=="vector_list") return false; @@ -141,6 +151,7 @@ Star::get_param(const String& param)const EXPORT(radius2); EXPORT(points); EXPORT(angle); + EXPORT(regular_polygon); EXPORT_NAME(); EXPORT_VERSION(); @@ -163,20 +174,20 @@ Star::get_param_vocab()const .set_local_name(_("Outer Radius")) .set_description(_("The radius of the outer points in the star")) .set_is_distance() - .set_origin("offset") + .set_origin("origin") ); ret.push_back(ParamDesc("radius2") .set_local_name(_("Inner Radius")) .set_description(_("The radius of the inner points in the star")) .set_is_distance() - .set_origin("offset") + .set_origin("origin") ); ret.push_back(ParamDesc("angle") .set_local_name(_("Angle")) .set_description(_("The orientation of the star")) - .set_origin("offset") + .set_origin("origin") ); ret.push_back(ParamDesc("points") @@ -184,5 +195,10 @@ Star::get_param_vocab()const .set_description(_("The number of points in the star")) ); + ret.push_back(ParamDesc("regular_polygon") + .set_local_name(_("Regular Polygon")) + .set_description(_("Whether to draw a star or a regular polygon")) + ); + return ret; }