"Project-Id-Version: Synfig Backend\n"
"Report-Msgid-Bugs-To: http://synfig.org/Bugs\n"
"POT-Creation-Date: 2009-10-07 01:26+0400\n"
-"PO-Revision-Date: 2009-10-09 21:14+0400\n"
+"PO-Revision-Date: 2010-01-18 20:40+0600\n"
"Last-Translator: Alexandre Prokoudine <alexandre.prokoudine@gmail.com>\n"
"Language-Team: Russian <gnome-cyr@lists.gnome.org>\n"
"MIME-Version: 1.0\n"
#: ../src/modules/example/metaballs.cpp:56
msgid "Metaballs"
-msgstr "Меташары"
+msgstr "Metaballs"
#: ../src/modules/example/metaballs.cpp:132
#: ../src/modules/mod_gradient/conicalgradient.cpp:106
#: ../src/modules/lyr_std/zoom.cpp:51 ../src/synfig/layer_pastecanvas.cpp:136
msgid "Zoom"
-msgstr "УвелиÑ\87ение"
+msgstr "Ð\9cаÑ\81Ñ\88Ñ\82абиÑ\80ование"
#: ../src/modules/lyr_std/zoom.cpp:97
msgid "Amount to zoom in"
#: ../src/synfig/layer_pastecanvas.cpp:137
msgid "Size of canvas"
-msgstr "Размерхолста"
+msgstr "Размер холста"
#: ../src/synfig/layer_pastecanvas.cpp:145
msgid "Children Lock"
#: ../src/synfig/layer_shape.cpp:1219
msgid "Winding Style"
-msgstr "СÑ\82илÑ\8c изгибов"
+msgstr "Ð\9eбÑ\80абоÑ\82ка взаимопеÑ\80еÑ\81еÑ\87ений"
#: ../src/synfig/layer_shape.cpp:1220
msgid "Winding style to use"
-msgstr "Ð\98Ñ\81полÑ\8cзÑ\83емÑ\8bй Ñ\81Ñ\82илÑ\8c изгибов"
+msgstr "Ð\9fÑ\80именÑ\8fемаÑ\8f обÑ\80абоÑ\82ка взаимопеÑ\80еÑ\81еÑ\87ений"
#: ../src/synfig/layer_shape.cpp:1222
msgid "Non Zero"
SYNFIG_LAYER_INIT(svg_layer);
SYNFIG_LAYER_SET_NAME(svg_layer,"svg_layer");
SYNFIG_LAYER_SET_LOCAL_NAME(svg_layer,N_("Import Svg"));
-SYNFIG_LAYER_SET_CATEGORY(svg_layer,N_("Do Not Use"));//Hide this layer in the menu
+SYNFIG_LAYER_SET_CATEGORY(svg_layer,CATEGORY_DO_NOT_USE);//Hide this layer in the menu
SYNFIG_LAYER_SET_VERSION(svg_layer,"0.1");
SYNFIG_LAYER_SET_CVS_ID(svg_layer,"$Id: layer_svg.cpp 2240 2008-11-22 15:35:33Z dooglus $");
** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
** Copyright (c) 2008 Chris Moore
** Copyright (c) 2009 Carlos A. Sosa Navarro
+** Copyright (c) 2009 Nikita Kitaev
**
** This package is free software; you can redistribute it and/or
** modify it under the terms of the GNU General Public License as
/* === G L O B A L S ======================================================= */
+//PARSER PREFERENCES
+
+//Seperate transformations: apply transformations on a per-layer basis, rather than on canvases
+#define SVG_SEP_TRANSFORMS 1
+
+//Resolve BLine transformations: resolve transformations instead of creating transformation layers
+#define SVG_RESOLVE_BLINE 1
+
/* === P R O C E D U R E S ================================================= */
Canvas::Handle
String
Svg_parser::get_id(){
if(!id_name.empty()) return id_name;
- return "id_arbitrario";
+ return "random_id";
}
void
Svg_parser::set_id(String source){
const char bad_chars[]=" :#@$^&()*";
- int inicio= source.find_last_of('/')+1;
- int fin= source.find_last_of('.');
- String x=source.substr(inicio,fin-inicio);
+ int start= source.find_last_of('/')+1;
+ int end= source.find_last_of('.');
+ String x=source.substr(start,end-start);
if(!x.empty()){
for(unsigned int i=0;i<sizeof(bad_chars);i++){
unsigned int pos=x.find_first_of(bad_chars[i]);
*/
//UPDATE
+
+/* === PARSERS ============================================================= */
+
void
Svg_parser::parser_node(const xmlpp::Node* node){
const xmlpp::ContentNode* nodeContent = dynamic_cast<const xmlpp::ContentNode*>(node);
parser_canvas(node);
}else if(nodename.compare("defs")==0){
parser_defs (node);
- }else if(nodename.compare("g")==0){
- if(set_canvas==0) parser_canvas (node);
- parser_layer (node,nodeRoot->add_child("layer"),"",NULL);
- return;
- }else if(nodename.compare("rect")==0){
- if(set_canvas==0) parser_canvas (node);
- parser_rect(node,nodeRoot,"",NULL);
- }else if(nodename.compare("polygon")==0){
- if(set_canvas==0) parser_canvas (node);
- parser_polygon(node,nodeRoot,"",NULL);
- }else if(nodename.compare("path")==0){
+ }else{
if(set_canvas==0) parser_canvas (node);
- parser_path (node,nodeRoot,"",NULL);
+ parser_graphics(node,nodeRoot,"",NULL);
+ if(nodename.compare("g")==0) return;
}
}
if(!nodeContent){
//parser elements
void
Svg_parser::parser_svg (const xmlpp::Node* node){
- //printf("un dia en algun lugar de la tierra media\n");
if(const xmlpp::Element* nodeElement = dynamic_cast<const xmlpp::Element*>(node)){
width =etl::strprintf("%f",getDimension(nodeElement->get_attribute_value("width")));
height =etl::strprintf("%f",getDimension(nodeElement->get_attribute_value("height")));
}
void
Svg_parser::parser_canvas (const xmlpp::Node* node){
- //printf("el campo de batalla parecia un lienzo de pintura\n");
if(const xmlpp::Element* nodeElement = dynamic_cast<const xmlpp::Element*>(node)){
if(width.compare("")==0){
width=nodeElement->get_attribute_value("width","");
nodeRoot->set_attribute("begin-time","0f");
nodeRoot->set_attribute("end-time","5s");
nodeRoot->set_attribute("bgcolor","0.500000 0.500000 0.500000 1.000000");
- //nodeRoot->add_child("name")->set_child_text("Synfig Animation 1");
if(!id_name.empty()) nodeRoot->add_child("name")->set_child_text(id_name);
else nodeRoot->add_child("name")->set_child_text("Synfig Animation 1");
}
set_canvas=1;
- AdjustPointUrl ();
}
void
-Svg_parser::parser_rect(const xmlpp::Node* node,xmlpp::Element* root,String parent_style,Matrix* mtx_parent){
+Svg_parser::parser_graphics(const xmlpp::Node* node,xmlpp::Element* root,String parent_style,Matrix* mtx_parent){
if(const xmlpp::Element* nodeElement = dynamic_cast<const xmlpp::Element*>(node)){
- Glib::ustring rect_id =nodeElement->get_attribute_value("id");
- Glib::ustring rect_style =nodeElement->get_attribute_value("style");
- Glib::ustring rect_x =nodeElement->get_attribute_value("x");
- Glib::ustring rect_y =nodeElement->get_attribute_value("y");
- Glib::ustring rect_width =nodeElement->get_attribute_value("width");
- Glib::ustring rect_height =nodeElement->get_attribute_value("height");
- //style
- String fill =loadAttribute("fill",rect_style,parent_style,"none");
- String fill_opacity =loadAttribute("fill-opacity",rect_style,parent_style,"1");
- String opacity =loadAttribute("opacity",rect_style,parent_style,"1");
- //matrix
- //it's some complicated
-
- //build
+ Glib::ustring nodename = node->get_name();
+ if (nodename.compare("g")==0 || nodename.compare("path")==0 || nodename.compare("polygon")==0 || nodename.compare("rect")==0){} else return;
- int typeFill=0;
- if(fill.compare(0,3,"url")==0){
- typeFill=2;
- root=nodeStartBasicLayer(root->add_child("layer"));
- }
- xmlpp::Element *child_rect=root->add_child("layer");
- child_rect->set_attribute("type","rectangle");
- child_rect->set_attribute("active","true");
- child_rect->set_attribute("version","0.2");
- child_rect->set_attribute("desc",rect_id);
-
- build_real(child_rect->add_child("param"),"z_depth",0.0);
- build_real(child_rect->add_child("param"),"amount",1.0);
- build_integer(child_rect->add_child("param"),"blend_method",0);
- build_color (child_rect->add_child("param"),getRed (fill),getGreen (fill),getBlue(fill),atof(opacity.data())*atof(fill_opacity.data()));
-
- float auxx=atof(rect_x.c_str());
- float auxy=atof(rect_y.c_str());
- coor2vect(&auxx,&auxy);
- build_vector (child_rect->add_child("param"),"point1",auxx,auxy);
- auxx= atof(rect_x.c_str()) + atof(rect_width.c_str());
- auxy= atof(rect_y.c_str()) + atof(rect_height.c_str());
- coor2vect(&auxx,&auxy);
- build_vector (child_rect->add_child("param"),"point2",auxx,auxy);
- if(typeFill==2){
- build_url (root->add_child("layer"),fill,mtx_parent);
- }
- }
-}
-void
-Svg_parser::parser_layer(const xmlpp::Node* node,xmlpp::Element* root,String parent_style,Matrix* mtx_parent){
- if(const xmlpp::Element* nodeElement = dynamic_cast<const xmlpp::Element*>(node)){
- Glib::ustring label =nodeElement->get_attribute_value("label");
- Glib::ustring style =nodeElement->get_attribute_value("style");
- Glib::ustring fill =nodeElement->get_attribute_value("fill");
+ //load sub-attributes
+ Glib::ustring id =nodeElement->get_attribute_value("id");
Glib::ustring transform =nodeElement->get_attribute_value("transform");
- String layer_style;
- if(!style.empty()){
- layer_style=style;
- }else if(!fill.empty()){
- layer_style.append("fill:");
- layer_style.append(fill);
- }else if(!parent_style.empty()){
- layer_style=parent_style;
- }
+ //resolve transformations
Matrix* mtx=NULL;
if(!transform.empty())
- mtx=build_transform (transform);
- if(mtx_parent){
- if(mtx)
- composeMatrix(&mtx,mtx_parent,mtx);
- else
- mtx=newMatrix (mtx_parent);
- }
- //build
- root->set_attribute("type","PasteCanvas");
- root->set_attribute("active","true");
- root->set_attribute("version","0.1");
- if(!label.empty()) root->set_attribute("desc",label);
- else root->set_attribute("desc","unknow layer");
-
- build_real(root->add_child("param"),"z_depth",0.0);
- build_real(root->add_child("param"),"amount",1.0);
- build_integer(root->add_child("param"),"blend_method",0);
- build_vector (root->add_child("param"),"origin",0,0);
-
- //printf(" atributos canvas ");
- //canvas
- xmlpp::Element *child_canvas=root->add_child("param");
- child_canvas->set_attribute("name","canvas");
- child_canvas=child_canvas->add_child("canvas");
- const xmlpp::ContentNode* nodeContent = dynamic_cast<const xmlpp::ContentNode*>(node);
- if(!nodeContent){
- xmlpp::Node::NodeList list = node->get_children();
- for(xmlpp::Node::NodeList::iterator iter = list.begin(); iter != list.end(); ++iter){
- Glib::ustring name =(*iter)->get_name();
- if(name.compare("g")==0){
- parser_layer (*iter,child_canvas->add_child("layer"),layer_style,mtx);
- }else if(name.compare("path")==0){
- parser_path (*iter,child_canvas,layer_style,mtx);
- }else if(name.compare("polygon")==0){
- parser_polygon (*iter,child_canvas,layer_style,mtx);
- }else if(name.compare("rect")==0){
- parser_rect (*iter,child_canvas,layer_style,mtx);
- }
- }
- }
- }
-}
-void
-Svg_parser::parser_polygon(const xmlpp::Node* node,xmlpp::Element* root,String parent_style,Matrix* mtx_parent){
- //printf("sus escudos parecian rombos y sus naves unos triangulos\n");
- if(const xmlpp::Element* nodeElement = dynamic_cast<const xmlpp::Element*>(node)){
- //load sub-attributes
- Glib::ustring polygon_style =nodeElement->get_attribute_value("style");
- Glib::ustring polygon_id =nodeElement->get_attribute_value("id");
- Glib::ustring polygon_points =nodeElement->get_attribute_value("points");
- Glib::ustring polygon_transform =nodeElement->get_attribute_value("transform");
- Glib::ustring polygon_fill =nodeElement->get_attribute_value("fill");
- String fill =loadAttribute("fill",polygon_style,parent_style,polygon_fill,"none");
- String fill_rule =loadAttribute("fill-rule",polygon_style,parent_style,"evenodd");
- String fill_opacity =loadAttribute("fill-opacity",polygon_style,parent_style,"1");
- String opacity =loadAttribute("opacity",polygon_style,parent_style,"1");
-
- //transforms
- Matrix* mtx=NULL;
- if(!polygon_transform.empty())
- mtx=build_transform (polygon_transform);
- if(mtx_parent){
- if(mtx)
- composeMatrix(&mtx,mtx_parent,mtx);
- else
- mtx=newMatrix (mtx_parent);
+ mtx=parser_transform (transform);
+ if (SVG_SEP_TRANSFORMS)
+ {
+ if(mtx_parent){
+ if(mtx)
+ composeMatrix(&mtx,mtx_parent,mtx);
+ else
+ mtx=newMatrix(mtx_parent);
+ }
}
- //points
- if(polygon_points.empty())
+ if(nodename.compare("g")==0){
+ parser_layer (node,root->add_child("layer"),parent_style,mtx);
return;
- std::list<Vertice*> k;
- std::vector<String> tokens=get_tokens_path (polygon_points);
- unsigned int i;
- float ax,ay; ax=ay=0;
- for(i=0;i<tokens.size();i++){
- ax=atof(tokens.at(i).data());
- i++; if(tokens.at(i).compare(",")==0) i++;
- ay=atof(tokens.at(i).data());
- //mtx
- if(mtx) transformPoint2D(mtx,&ax,&ay);
- //adjust
- coor2vect(&ax,&ay);
- //save
- k.push_back(nuevoVertice(ax,ay));
}
- //escritura
- xmlpp::Element *child_polygon;
-
- //gradient
- int typeFill=0;
- if(fill.compare(0,3,"url")==0){
- typeFill=2;//gradient
- root=nodeStartBasicLayer(root->add_child("layer"));
- }
- child_polygon=root->add_child("layer");
- child_polygon->set_attribute("type","polygon");
- child_polygon->set_attribute("active","true");
- child_polygon->set_attribute("version","0.1");
- child_polygon->set_attribute("desc",polygon_id);
- build_param (child_polygon->add_child("param"),"z_depth","real","0.0000000000");
- build_param (child_polygon->add_child("param"),"amount","real","1.0000000000");
- build_param (child_polygon->add_child("param"),"blend_method","integer","0");
- build_color (child_polygon->add_child("param"),getRed(fill),getGreen(fill),getBlue(fill),atof(fill_opacity.data())*atof(opacity.data()));
- build_vector(child_polygon->add_child("param"),"offset",0,0);
- build_param (child_polygon->add_child("param"),"invert","bool","false");
- build_param (child_polygon->add_child("param"),"antialias","bool","true");
- build_param (child_polygon->add_child("param"),"feather","real","0.0000000000");
- build_param (child_polygon->add_child("param"),"blurtype","integer","1");
- if(fill_rule.compare("evenodd")==0) build_param (child_polygon->add_child("param"),"winding_style","integer","1");
- else build_param (child_polygon->add_child("param"),"winding_style","integer","0");
- build_points (child_polygon->add_child("param"),k);
-
- if(typeFill==2){
- build_url(root->add_child("layer"),fill,mtx);
- }
- }
-}
-void
-Svg_parser::parser_path(const xmlpp::Node* node,xmlpp::Element* root,String parent_style,Matrix* mtx_parent){
- //printf("pensamos que atacarian de frente pero hicieron una curva\n");
- if(const xmlpp::Element* nodeElement = dynamic_cast<const xmlpp::Element*>(node)){
- //load sub-attributes
- Glib::ustring path_style =nodeElement->get_attribute_value("style");
- Glib::ustring path_id =nodeElement->get_attribute_value("id");
- Glib::ustring path_d =nodeElement->get_attribute_value("d");
- Glib::ustring path_transform =nodeElement->get_attribute_value("transform");
- Glib::ustring path_fill =nodeElement->get_attribute_value("fill");
-
- String fill =loadAttribute("fill",path_style,parent_style,path_fill,"none");
- String fill_rule =loadAttribute("fill-rule",path_style,parent_style,"evenodd");
- String stroke =loadAttribute("stroke",path_style,parent_style,"none");
- String stroke_width =loadAttribute("stroke-width",path_style,parent_style,"1px");
- String stroke_linecap =loadAttribute("stroke-linecap",path_style,parent_style,"butt");
- String stroke_linejoin =loadAttribute("stroke-linejoin",path_style,parent_style,"miter");
- String stroke_opacity =loadAttribute("stroke-opacity",path_style,parent_style,"1");
- String fill_opacity =loadAttribute("fill-opacity",path_style,parent_style,"1");
- String opacity =loadAttribute("opacity",path_style,parent_style,"1");
- //resolve transformations
- Matrix* mtx=NULL;
- if(!path_transform.empty())
- mtx=build_transform (path_transform);
- if(mtx_parent){
- if(mtx)
- composeMatrix(&mtx,mtx_parent,mtx);
- else
- mtx=newMatrix(mtx_parent);
- }
- //parser path_d attribute, this is obviously important
- std::list<std::list<Vertice*> > k;
- k=parser_path_d (path_d,mtx);
+ Glib::ustring obj_style =nodeElement->get_attribute_value("style");
+ Glib::ustring obj_fill =nodeElement->get_attribute_value("fill");
+
+ //style
+ String fill =loadAttribute("fill",obj_style,parent_style,obj_fill,"none");
+ String fill_rule =loadAttribute("fill-rule",obj_style,parent_style,"evenodd");
+ String stroke =loadAttribute("stroke",obj_style,parent_style,"none");
+ String stroke_width =loadAttribute("stroke-width",obj_style,parent_style,"1px");
+ String stroke_linecap =loadAttribute("stroke-linecap",obj_style,parent_style,"butt");
+ String stroke_linejoin =loadAttribute("stroke-linejoin",obj_style,parent_style,"miter");
+ String stroke_opacity =loadAttribute("stroke-opacity",obj_style,parent_style,"1");
+ String fill_opacity =loadAttribute("fill-opacity",obj_style,parent_style,"1");
+ String opacity =loadAttribute("opacity",obj_style,parent_style,"1");
+
- //escribir
- int typeFill=0; //nothing
- int typeStroke=0;//nothing
//Fill
+ int typeFill=0; //nothing
+
if(fill.compare("none")!=0){
typeFill=1; //simple
}
typeFill=2; //gradient
}
//Stroke
+ int typeStroke=0;//nothing
+
if(stroke.compare("none")!=0){
typeStroke=1; //simple
}
if(typeStroke==1 && stroke.compare(0,3,"url")==0){
typeStroke=2; //gradient
}
- String bline_id;
- String offset_id;
- int n=k.size();
- if(n!=1){ //if n is > than 1 then we must create a paste canvas for all paths
- root=nodeStartBasicLayer(root->add_child("layer"));
+
+ xmlpp::Element* child_layer = root;
+ xmlpp::Element* child_fill;
+ xmlpp::Element* child_stroke;
+
+ //make simple fills
+ if(nodename.compare("rect")==0 && typeFill!=0){
+ if (mtx) child_layer = nodeStartBasicLayer(root->add_child("layer"), id);
+ child_fill=child_layer;
+ parser_rect(nodeElement,child_fill,fill,fill_opacity,opacity);
+ if(typeFill==2){
+ build_fill (child_fill,fill,NULL);
+ }
+ parser_effects(nodeElement,child_layer,parent_style,mtx);
+ return;
}
- std::list<std::list<Vertice*> >::iterator aux = k.begin();
- for (; aux!=k.end(); aux++){
- if(typeFill!=0 && typeStroke!=0){
- bline_id=new_guid();
- offset_id=new_guid();
+ if ((!(SVG_RESOLVE_BLINE) && mtx) || typeFill==2 || typeStroke==2)
+ child_layer = nodeStartBasicLayer(root->add_child("layer"), id);
+ child_fill=child_layer;
+ child_stroke=child_layer;
+
+ //=======================================================================
+
+ std::list<BLine*> k;
+ //if we are creating a bline
+
+ //First, create the list of Verteces
+ if (SVG_RESOLVE_BLINE) {
+ if(nodename.compare("path")==0){
+ k=parser_path_d (nodeElement->get_attribute_value("d"),mtx);
+ } else if(nodename.compare("polygon")==0){
+ k=parser_path_polygon (nodeElement->get_attribute_value("points"),mtx);
}
- if(typeFill==1 || typeFill==2){//region layer
- xmlpp::Element *child_fill=root;
- if(n==1 && typeFill==2){//open gradient or url (fill)
- child_fill=nodeStartBasicLayer(root->add_child("layer"));
- }
+ } else {
+ if(nodename.compare("path")==0){
+ k=parser_path_d (nodeElement->get_attribute_value("d"),NULL);
+ } else if(nodename.compare("polygon")==0){
+ k=parser_path_polygon (nodeElement->get_attribute_value("points"),NULL);
+ }
+ }
+
+ std::list<BLine *>::iterator aux;
+ //int n = k.size();
+
+ if(typeFill!=0){//region layer
+ /*if(typeFill==2){
+ child_fill=nodeStartBasicLayer(child_fill->add_child("layer"));
+ }*/
+ for (aux = k.begin(); aux!=k.end(); aux++){
xmlpp::Element *child_region=child_fill->add_child("layer");
child_region->set_attribute("type","region");
child_region->set_attribute("active","true");
child_region->set_attribute("version","0.1");
- child_region->set_attribute("desc",path_id);
+ child_region->set_attribute("desc",id);
build_param (child_region->add_child("param"),"z_depth","real","0.0000000000");
build_param (child_region->add_child("param"),"amount","real","1.0000000000");
build_param (child_region->add_child("param"),"blend_method","integer","0");
build_color (child_region->add_child("param"),getRed(fill),getGreen(fill),getBlue(fill),atof(fill_opacity.data())*atof(opacity.data()));
- if(offset_id.empty()) build_vector (child_region->add_child("param"),"offset",0,0);
- else build_vector (child_region->add_child("param"),"offset",0,0,offset_id);
+ build_vector (child_region->add_child("param"),"offset",0,0, *(*aux)->offset_id );
build_param (child_region->add_child("param"),"invert","bool","false");
build_param (child_region->add_child("param"),"antialias","bool","true");
build_param (child_region->add_child("param"),"feather","real","0.0000000000");
if(fill_rule.compare("evenodd")==0) build_param (child_region->add_child("param"),"winding_style","integer","1");
else build_param (child_region->add_child("param"),"winding_style","integer","0");
- build_bline (child_region->add_child("param"),*aux,loop,bline_id);
-
- if(n==1 && typeFill==2){ //gradient in onto mode (fill)
- build_url(child_fill->add_child("layer"),fill,mtx);
- }
+ build_bline (child_region->add_child("param"),*(*aux)->points,(*aux)->loop,*(*aux)->bline_id);
}
+ }
+ if(typeFill==2){ //gradient in onto mode (fill)
+ if (SVG_RESOLVE_BLINE)
+ build_fill(child_fill,fill,mtx);
+ else
+ build_fill(child_fill,fill,NULL);
+ }
- if(typeStroke==1 || typeStroke==2){ //layer outline
- xmlpp::Element *child_stroke=root;
- if(n==1 && typeStroke==2){//open gradient in straigth onto (stroke)
- child_stroke=nodeStartBasicLayer(root->add_child("layer"));
- }
+ if(typeStroke!=0){//outline layer
+ if(typeStroke==2){
+ child_stroke=nodeStartBasicLayer(child_stroke->add_child("layer"),"stroke");
+ }
+ for (aux=k.begin(); aux!=k.end(); aux++){
xmlpp::Element *child_outline=child_stroke->add_child("layer");
child_outline->set_attribute("type","outline");
child_outline->set_attribute("active","true");
child_outline->set_attribute("version","0.2");
- child_outline->set_attribute("desc",path_id);
+ child_outline->set_attribute("desc",id);
build_param (child_outline->add_child("param"),"z_depth","real","0.0000000000");
build_param (child_outline->add_child("param"),"amount","real","1.0000000000");
build_param (child_outline->add_child("param"),"blend_method","integer","0");
build_color (child_outline->add_child("param"),getRed(stroke),getGreen(stroke),getBlue(stroke),atof(stroke_opacity.data())*atof(opacity.data()));
- if(offset_id.empty()) build_vector (child_outline->add_child("param"),"offset",0,0);
- else build_vector (child_outline->add_child("param"),"offset",0,0,offset_id);
+ build_vector (child_outline->add_child("param"),"offset",0,0,*(*aux)->offset_id);
build_param (child_outline->add_child("param"),"invert","bool","false");
build_param (child_outline->add_child("param"),"antialias","bool","true");
build_param (child_outline->add_child("param"),"feather","real","0.0000000000");
//outline in nonzero
build_param (child_outline->add_child("param"),"winding_style","integer","0");
- build_bline (child_outline->add_child("param"),*aux,loop,bline_id);
+ build_bline (child_outline->add_child("param"),*(*aux)->points,(*aux)->loop,*(*aux)->bline_id);
stroke_width=etl::strprintf("%f",getDimension(stroke_width)/kux);
build_param (child_outline->add_child("param"),"width","real",stroke_width);
}
build_param (child_outline->add_child("param"),"loopyness","real","1.0000000000");
build_param (child_outline->add_child("param"),"homogeneous_width","bool","true");
-
- if(n==1 && typeStroke==2){ //gradient in onto mode (stroke)
- build_url(child_stroke->add_child("layer"),stroke,mtx);
- }
- }
- }
- if(n!=1){//only fill for several canvas in one path
- if(typeFill==2){
- build_url(root->add_child("layer"),fill,mtx);
}
+
+ if(typeStroke==2){ //gradient in onto mode (stroke)
+ if (SVG_RESOLVE_BLINE)
+ build_fill(child_stroke,stroke,mtx);
+ else
+ build_fill(child_stroke,stroke,NULL);
+ }
}
+
+ if (SVG_RESOLVE_BLINE)
+ parser_effects(nodeElement,child_layer,parent_style,NULL);
+ else
+ parser_effects(nodeElement,child_layer,parent_style,mtx);
}
}
-std::vector<String>
-Svg_parser::get_tokens_path(String path){ //mini path lexico-parser
- std::vector<String> tokens;
- String buffer;
- int e=0;
- unsigned int i=0;
- char a;
- while(i<path.size()){
- a=path.at(i);
- switch(e){
- case 0: //initial state
- if(a=='m'){ e=1; i++;}
- else if(a=='c'){ e= 2; i++;}
- else if(a=='q'){ e= 3; i++;}
- else if(a=='t'){ e= 4; i++;}
- else if(a=='a'){ e= 5; i++;}
- else if(a=='l'){ e= 6; i++;}
- else if(a=='v'){ e= 7; i++;}
- else if(a=='h'){ e= 8; i++;}
- else if(a=='M'){ e= 9; i++;}
- else if(a=='C'){ e=10; i++;}
- else if(a=='Q'){ e=11; i++;}
- else if(a=='T'){ e=12; i++;}
- else if(a=='A'){ e=13; i++;}
- else if(a=='L'){ e=14; i++;}
- else if(a=='V'){ e=15; i++;}
- else if(a=='H'){ e=16; i++;}
- else if(a=='z' || a=='Z'){ e=17; i++;}
- else if(a=='-' ||a=='.'|| isdigit (a)){ e=18;}
- else if(a==','){ e=19; i++;}
- else if(a==' '){i++;}
- break;
- //relative
- case 1 : tokens.push_back("m"); e=0; break;//move
- case 2 : tokens.push_back("c"); e=0; break;//curve
- case 3 : tokens.push_back("q"); e=0; break;//quadratic
- case 4 : tokens.push_back("t"); e=0; break;//smooth quadratic
- case 5 : tokens.push_back("a"); e=0; break;//elliptic arc
- case 6 : tokens.push_back("l"); e=0; break;//line to
- case 7 : tokens.push_back("v"); e=0; break;//vertical
- case 8 : tokens.push_back("h"); e=0; break;//horizontal
- //absolute
- case 9 : tokens.push_back("M"); e=0; break;
- case 10: tokens.push_back("C"); e=0; break;
- case 11: tokens.push_back("Q"); e=0; break;
- case 12: tokens.push_back("T"); e=0; break;
- case 13: tokens.push_back("A"); e=0; break;
- case 14: tokens.push_back("L"); e=0; break;
- case 15: tokens.push_back("V"); e=0; break;
- case 16: tokens.push_back("H"); e=0; break;
+/* === LAYER PARSERS ======================================================= */
- case 17: tokens.push_back("z"); e=0; break;//loop
- case 18: if(a=='-'||a=='.'|| isdigit (a)){
- buffer.append(path.substr(i,1));i++;
- }else{
- e=20;
- }
- break;
- case 19: tokens.push_back(","); e=0; break;
- case 20: tokens.push_back(buffer);
- buffer.clear();
- e=0; break;
- default: break;
+void
+Svg_parser::parser_layer(const xmlpp::Node* node,xmlpp::Element* root,String parent_style,Matrix* mtx){
+ if(const xmlpp::Element* nodeElement = dynamic_cast<const xmlpp::Element*>(node)){
+ Glib::ustring label =nodeElement->get_attribute_value("label");
+ Glib::ustring style =nodeElement->get_attribute_value("style");
+ Glib::ustring fill =nodeElement->get_attribute_value("fill");
+
+ String layer_style;
+ if(!style.empty()){
+ layer_style=style;
+ }else if(!fill.empty()){
+ layer_style.append("fill:");
+ layer_style.append(fill);
+ }else if(!parent_style.empty()){
+ layer_style=parent_style;
}
+ //build
+ root->set_attribute("type","PasteCanvas");
+ root->set_attribute("active","true");
+ root->set_attribute("version","0.1");
+ if(!label.empty()) root->set_attribute("desc",label);
+ else root->set_attribute("desc","Inline Canvas");
+
+ build_real(root->add_child("param"),"z_depth",0.0);
+ build_real(root->add_child("param"),"amount",1.0);
+ build_integer(root->add_child("param"),"blend_method",0);
+ build_vector (root->add_child("param"),"origin",0,0);
+
+ //printf(" canvas attributes ");
+ //canvas
+ xmlpp::Element *child_canvas=root->add_child("param");
+ child_canvas->set_attribute("name","canvas");
+ child_canvas=child_canvas->add_child("canvas");
+ const xmlpp::ContentNode* nodeContent = dynamic_cast<const xmlpp::ContentNode*>(node);
+ if(!nodeContent){
+ xmlpp::Node::NodeList list = node->get_children();
+ for(xmlpp::Node::NodeList::iterator iter = list.begin(); iter != list.end(); ++iter){
+ Glib::ustring name =(*iter)->get_name();
+ parser_graphics (*iter,child_canvas,layer_style,mtx);
+ }
+ }
+ if (SVG_SEP_TRANSFORMS) parser_effects(nodeElement,child_canvas,parent_style,NULL);
+ else parser_effects(nodeElement,child_canvas,parent_style,mtx);
}
- switch(e){//last element
- case 1 : tokens.push_back("m"); break;
- case 2 : tokens.push_back("c"); break;
- case 3 : tokens.push_back("q"); break;
- case 4 : tokens.push_back("t"); break;
- case 5 : tokens.push_back("a"); break;
- case 6 : tokens.push_back("l"); break;
- case 7 : tokens.push_back("v"); break;
- case 8 : tokens.push_back("h"); break;
- case 9 : tokens.push_back("M"); break;
- case 10: tokens.push_back("C"); break;
- case 11: tokens.push_back("Q"); break;
- case 12: tokens.push_back("T"); break;
- case 13: tokens.push_back("A"); break;
- case 14: tokens.push_back("L"); break;
- case 15: tokens.push_back("V"); break;
- case 16: tokens.push_back("H"); break;
- case 17: tokens.push_back("z"); break;
- case 18: tokens.push_back(buffer); break;
- case 19: tokens.push_back(","); break;
- case 20: tokens.push_back(buffer); break;
- default: break;
+}
+
+void
+Svg_parser::parser_rect(const xmlpp::Element* nodeElement,xmlpp::Element* root,String fill, String fill_opacity, String opacity){
+ Glib::ustring rect_id =nodeElement->get_attribute_value("id");
+ Glib::ustring rect_x =nodeElement->get_attribute_value("x");
+ Glib::ustring rect_y =nodeElement->get_attribute_value("y");
+ Glib::ustring rect_width =nodeElement->get_attribute_value("width");
+ Glib::ustring rect_height =nodeElement->get_attribute_value("height");
+
+ xmlpp::Element *child_rect=root->add_child("layer");
+ child_rect->set_attribute("type","rectangle");
+ child_rect->set_attribute("active","true");
+ child_rect->set_attribute("version","0.2");
+ child_rect->set_attribute("desc",rect_id);
+
+ build_real(child_rect->add_child("param"),"z_depth",0.0);
+ build_real(child_rect->add_child("param"),"amount",1.0);
+ build_integer(child_rect->add_child("param"),"blend_method",0);
+ build_color (child_rect->add_child("param"),getRed (fill),getGreen (fill),getBlue(fill),atof(opacity.data())*atof(fill_opacity.data()));
+
+ float auxx=atof(rect_x.c_str());
+ float auxy=atof(rect_y.c_str());
+ coor2vect(&auxx,&auxy);
+ build_vector (child_rect->add_child("param"),"point1",auxx,auxy);
+ auxx= atof(rect_x.c_str()) + atof(rect_width.c_str());
+ auxy= atof(rect_y.c_str()) + atof(rect_height.c_str());
+ coor2vect(&auxx,&auxy);
+ build_vector (child_rect->add_child("param"),"point2",auxx,auxy);
+
+
+}
+
+/* === CONVERT TO PATH PARSERS ============================================= */
+
+std::list<BLine *>
+Svg_parser::parser_path_polygon(Glib::ustring polygon_points, Matrix* mtx){
+ std::list<BLine *> k0;
+ if(polygon_points.empty())
+ return k0;
+ std::list<Vertex*> points;
+ std::vector<String> tokens=get_tokens_path (polygon_points);
+ unsigned int i;
+ float ax,ay; ax=ay=0;
+ for(i=0;i<tokens.size();i++){
+ ax=atof(tokens.at(i).data());
+ i++; if(tokens.at(i).compare(",")==0) i++;
+ ay=atof(tokens.at(i).data());
+ //mtx
+ if(mtx) transformPoint2D(mtx,&ax,&ay);
+ //adjust
+ coor2vect(&ax,&ay);
+ //save
+ points.push_back(newVertex(ax,ay));
}
- return tokens;
+ k0.push_front(newBLine(&points, true));
+ return k0;
}
-std::list<std::list<Vertice*> >
+std::list<BLine *>
Svg_parser::parser_path_d(String path_d,Matrix* mtx){
- std::list<std::list<Vertice*> > k;
- std::list<Vertice*> k1;
- float ax,ay,tgx,tgy,tgx2,tgy2;//each method
- float actual_x=0,actual_y=0;//for relative methods;
- loop=false;
- unsigned int i;
+ std::list<BLine *> k;
+ std::list<Vertex*> k1;
+
std::vector<String> tokens=get_tokens_path(path_d);
- for(i=0;i<tokens.size();i++){
- if(tokens.at(i).compare("M")==0){//absolute move to
- if(!k1.empty())
- k.push_front(k1);
- k1.clear();
+ String command="M"; //the current command
+ float ax,ay,tgx,tgy,tgx2,tgy2;//each method
+ ax=ay=0;
+ float actual_x=0,actual_y=0; //in svg coordinate space
+ float old_x=0,old_y=0; //needed in rare cases
+ float init_x=0,init_y=0; //for closepath commands
+
+ for(unsigned int i=0;i<tokens.size();i++){
+ //if the token is a command, change the current command
+ if(tokens.at(i).compare("M")==0 || tokens.at(i).compare("m")==0 || tokens.at(i).compare("L")==0 || tokens.at(i).compare("l")==0 || tokens.at(i).compare("H")==0 || tokens.at(i).compare("h")==0 || tokens.at(i).compare("V")==0 || tokens.at(i).compare("v")==0 || tokens.at(i).compare("C")==0 || tokens.at(i).compare("c")==0 || tokens.at(i).compare("S")==0 || tokens.at(i).compare("s")==0 || tokens.at(i).compare("Q")==0 || tokens.at(i).compare("q")==0 || tokens.at(i).compare("T")==0 || tokens.at(i).compare("t")==0 || tokens.at(i).compare("A")==0 || tokens.at(i).compare("a")==0 || tokens.at(i).compare("z")==0) {
+ command=tokens.at(i);
+ i++;
+ }
+
+ old_x=actual_x;
+ old_y=actual_y;
+ //if command is absolute, set actual_x/y to zero
+ if(command.compare("M")==0 || command.compare("L")==0 || command.compare("C")==0 || command.compare("S")==0 || command.compare("Q")==0 || command.compare("T")==0 || command.compare("A")==0 || command.compare("H")==0 || command.compare("V")==0) {
+ actual_x=0;
+ actual_y=0;
+ }
+
+ //now parse the commands
+ if(command.compare("M")==0 || command.compare("m")==0){ //move to
+ if(!k1.empty()) {
+ k.push_front(newBLine(&k1, false));
+ k1.clear();
+ }
//read
- i++; ax=atof(tokens.at(i).data());
+ actual_x+=atof(tokens.at(i).data());
i++; if(tokens.at(i).compare(",")==0) i++;
- ay=atof(tokens.at(i).data());
- actual_x=ax;
- actual_y=ay;
+ actual_y+=atof(tokens.at(i).data());
+
+ init_x=actual_x;
+ init_y=actual_y;
+ ax=actual_x;
+ ay=actual_y;
//operate and save
if(mtx) transformPoint2D(mtx,&ax,&ay);
coor2vect(&ax,&ay);
- k1.push_back(nuevoVertice (ax,ay)); //first element
+ k1.push_back(newVertex (ax,ay)); //first element
setSplit(k1.back(),TRUE);
- }else if(tokens.at(i).compare("C")==0){ //absolute curve
+ //"If a moveto is followed by multiple pairs of coordinates,
+ // the subsequent pairs are treated as implicit lineto commands."
+ if (command.compare("M")==0)
+ command="L";
+ else
+ command="l";
+ }else if(command.compare("C")==0 || command.compare("c")==0){ //curve
//tg2
- i++; tgx2=atof(tokens.at(i).data());
+ tgx2=actual_x+atof(tokens.at(i).data());
i++; if(tokens.at(i).compare(",")==0) i++;
- tgy2=atof(tokens.at(i).data());
+ tgy2=actual_y+atof(tokens.at(i).data());
//tg1
- i++; tgx=atof(tokens.at(i).data());
+ i++; tgx=actual_x+atof(tokens.at(i).data());
i++; if(tokens.at(i).compare(",")==0) i++;
- tgy=atof(tokens.at(i).data());
+ tgy=actual_y+atof(tokens.at(i).data());
//point
- i++; ax=atof(tokens.at(i).data());
+ i++; actual_x+=atof(tokens.at(i).data());
i++; if(tokens.at(i).compare(",")==0) i++;
- ay=atof(tokens.at(i).data());
- actual_x=ax;
- actual_y=ay;
- //mtx
+ actual_y+=atof(tokens.at(i).data());
+
+ ax=actual_x;
+ ay=actual_y;
+ //mtx
if(mtx){
transformPoint2D(mtx,&tgx2,&tgy2);
transformPoint2D(mtx,&ax,&ay);
transformPoint2D(mtx,&tgx,&tgy);
}
- //ajust
+ //adjust
coor2vect(&tgx2,&tgy2);
coor2vect(&ax,&ay);
coor2vect(&tgx,&tgy);
if(isFirst(k1.front(),ax,ay)){
setTg1(k1.front(),k1.front()->x,k1.front()->y,tgx,tgy);
}else{
- k1.push_back(nuevoVertice (ax,ay));
+ k1.push_back(newVertex (ax,ay));
setTg1(k1.back(),k1.back()->x,k1.back()->y,tgx,tgy);
setSplit(k1.back(),TRUE);
}
- }else if(tokens.at(i).compare("Q")==0){ //absolute quadractic curve
+ }else if(command.compare("Q")==0 || command.compare("q")==0){ //quadractic curve
//tg1 and tg2
- i++; tgx=ax=atof(tokens.at(i).data());
+ tgx=actual_x+atof(tokens.at(i).data());
i++; if(tokens.at(i).compare(",")==0) i++;
- tgy=ay=atof(tokens.at(i).data());
+ tgy=actual_y+atof(tokens.at(i).data());
//point
- i++; ax=atof(tokens.at(i).data());
+ i++; actual_x+=atof(tokens.at(i).data());
i++; if(tokens.at(i).compare(",")==0) i++;
- ay=atof(tokens.at(i).data());
- actual_x=ax;
- actual_y=ay;
+ actual_y+=atof(tokens.at(i).data());
+
+ ax=actual_x;
+ ay=actual_y;
//mtx
if(mtx){
transformPoint2D(mtx,&ax,&ay);
//save
setTg1(k1.back(),k1.back()->x,k1.back()->y,tgx,tgy);
setSplit(k1.back(),FALSE);
- k1.push_back(nuevoVertice (ax,ay));
+ k1.push_back(newVertex (ax,ay));
setTg1(k1.back(),k1.back()->x,k1.back()->y,tgx,tgy);
- }else if(tokens.at(i).compare("L")==0){ //absolute line to
+ }else if(command.compare("L")==0 || command.compare("l")==0){ //line to
//point
- i++; ax=atof(tokens.at(i).data());
+ actual_x+=atof(tokens.at(i).data());
i++; if(tokens.at(i).compare(",")==0) i++;
- ay=atof(tokens.at(i).data());
- actual_x=ax;
- actual_y=ay;
- //mtx
- if(mtx) transformPoint2D(mtx,&ax,&ay);
- //adjust
- coor2vect(&ax,&ay);
- //save
- setTg2(k1.back(),k1.back()->x,k1.back()->y,k1.back()->x,k1.back()->y);
- if(isFirst(k1.front(),ax,ay)){
- setTg1(k1.front(),k1.front()->x,k1.front()->y,k1.front()->x,k1.front()->y);
- }else{
- k1.push_back(nuevoVertice(ax,ay));
- setTg1(k1.back(),k1.back()->x,k1.back()->y,k1.back()->x,k1.back()->y);
- }
- }else if(tokens.at(i).compare("l")==0){//relative line to
- //point read
- i++; ax=atof(tokens.at(i).data());
- i++; if(tokens.at(i).compare(",")==0) i++;
- ay=atof(tokens.at(i).data());
- //relative
- ax=actual_x+ax;
- ay=actual_y+ay;
- actual_x=ax;
- actual_y=ay;
- //mtx
- if(mtx) transformPoint2D(mtx,&ax,&ay);
- //adjust
- coor2vect(&ax,&ay);
- //save
- setTg2(k1.back(),k1.back()->x,k1.back()->y,k1.back()->x,k1.back()->y);
- if(isFirst(k1.front(),ax,ay)){
- setTg1(k1.front(),k1.front()->x,k1.front()->y,k1.front()->x,k1.front()->y);
- }else{
- k1.push_back(nuevoVertice(ax,ay));
- setTg1(k1.back(),k1.back()->x,k1.back()->y,k1.back()->x,k1.back()->y);
- }
- }else if(tokens.at(i).compare("H")==0){//absolute horizontal move
- //the same that L but only Horizontal movement
- //point
- i++; ax=atof(tokens.at(i).data());
- ay=actual_y;
- actual_x=ax;
- actual_y=ay;
- //mtx
- if(mtx) transformPoint2D(mtx,&ax,&ay);
- //adjust
- coor2vect(&ax,&ay);
- //save
- setTg2(k1.back(),k1.back()->x,k1.back()->y,k1.back()->x,k1.back()->y);
- if(isFirst(k1.front(),ax,ay)){
- setTg1(k1.front(),k1.front()->x,k1.front()->y,k1.front()->x,k1.front()->y);
- }else{
- k1.push_back(nuevoVertice(ax,ay));
- setTg1(k1.back(),k1.back()->x,k1.back()->y,k1.back()->x,k1.back()->y);
- }
- }else if(tokens.at(i).compare("h")==0){//horizontal relative
- i++; ax=atof(tokens.at(i).data());
- ax=actual_x+ax;
+ actual_y+=atof(tokens.at(i).data());
+
+ ax=actual_x;
ay=actual_y;
- actual_x=ax;
- actual_y=ay;
//mtx
if(mtx) transformPoint2D(mtx,&ax,&ay);
//adjust
if(isFirst(k1.front(),ax,ay)){
setTg1(k1.front(),k1.front()->x,k1.front()->y,k1.front()->x,k1.front()->y);
}else{
- k1.push_back(nuevoVertice(ax,ay));
+ k1.push_back(newVertex(ax,ay));
setTg1(k1.back(),k1.back()->x,k1.back()->y,k1.back()->x,k1.back()->y);
}
- }else if(tokens.at(i).compare("V")==0){//vertical absolute
+ }else if(command.compare("H")==0 || command.compare("h")==0){// horizontal move
+ //the same that L but only Horizontal movement
//point
- i++; ay=atof(tokens.at(i).data());
+ actual_x+=atof(tokens.at(i).data());
+
ax=actual_x;
- actual_x=ax;
- actual_y=ay;
+ ay=old_y;
//mtx
if(mtx) transformPoint2D(mtx,&ax,&ay);
//adjust
if(isFirst(k1.front(),ax,ay)){
setTg1(k1.front(),k1.front()->x,k1.front()->y,k1.front()->x,k1.front()->y);
}else{
- k1.push_back(nuevoVertice(ax,ay));
+ k1.push_back(newVertex(ax,ay));
setTg1(k1.back(),k1.back()->x,k1.back()->y,k1.back()->x,k1.back()->y);
}
- }else if(tokens.at(i).compare("v")==0){//relative
+ }else if(command.compare("V")==0 || command.compare("v")==0){//vertical
//point
- i++; ay=atof(tokens.at(i).data());
- ax=actual_x;
- ay=actual_y+ay;
- actual_x=ax;
- actual_y=ay;
+ actual_y+=atof(tokens.at(i).data());
+
+ ax=old_x;
+ ay=actual_y;
//mtx
if(mtx) transformPoint2D(mtx,&ax,&ay);
//adjust
if(isFirst(k1.front(),ax,ay)){
setTg1(k1.front(),k1.front()->x,k1.front()->y,k1.front()->x,k1.front()->y);
}else{
- k1.push_back(nuevoVertice(ax,ay));
+ k1.push_back(newVertex(ax,ay));
setTg1(k1.back(),k1.back()->x,k1.back()->y,k1.back()->x,k1.back()->y);
}
- }else if(tokens.at(i).compare("T")==0){// I don't know what does it
- }else if(tokens.at(i).compare("A")==0){//elliptic arc
+ }else if(command.compare("T")==0 || command.compare("t")==0){// I don't know what does it
+ actual_x+=atof(tokens.at(i).data());
+ i++; if(tokens.at(i).compare(",")==0) i++;
+ actual_y+=atof(tokens.at(i).data());
+ }else if(command.compare("A")==0 || command.compare("a")==0){//elliptic arc
//isn't complete support, is only for circles
//this curve have 6 parameters
- //radio
- float radio_x,radio_y;
+ //radius
+ float radius_x,radius_y;
float angle;
bool sweep,large;
- //radio
- i++; radio_x=atof(tokens.at(i).data());
+ //radius
+ radius_x=atof(tokens.at(i).data());
i++; if(tokens.at(i).compare(",")==0) i++;
- radio_y=atof(tokens.at(i).data());
+ radius_y=atof(tokens.at(i).data());
//angle
i++; angle=atof(tokens.at(i).data());
//flags
i++; large=atoi(tokens.at(i).data());
i++; sweep=atoi(tokens.at(i).data());
//point
- i++; ax=atof(tokens.at(i).data());
+ i++; actual_x+=atof(tokens.at(i).data());
i++; if(tokens.at(i).compare(",")==0) i++;
- ay=atof(tokens.at(i).data());
+ actual_y+=atof(tokens.at(i).data());
//how to draw?
if(!large && !sweep){
//points
- tgx2 = actual_x + radio_x*0.5;
- tgy2 = actual_y ;
- tgx = ax;
- tgy = ay + radio_y*0.5;
- actual_x=ax;
- actual_y=ay;
+ tgx2 = old_x + radius_x*0.5;
+ tgy2 = old_y ;
+ tgx = actual_x;
+ tgy = actual_y + radius_y*0.5;
+
+ ax=actual_x;
+ ay=actual_y;
//transformations
if(mtx){
transformPoint2D(mtx,&tgx2,&tgy2);
if(isFirst(k1.front(),ax,ay)){
setTg1(k1.front(),k1.front()->x,k1.front()->y,tgx,tgy);
}else{
- k1.push_back(nuevoVertice (ax,ay));
+ k1.push_back(newVertex (ax,ay));
setTg1(k1.back(),k1.back()->x,k1.back()->y,tgx,tgy);
setSplit(k1.back(),TRUE);
}
}else if(!large && sweep){
//points
- tgx2 = actual_x;
- tgy2 = actual_y + radio_y*0.5;
- tgx = ax + radio_x*0.5;
- tgy = ay ;
- actual_x=ax;
- actual_y=ay;
+ tgx2 = old_x;
+ tgy2 = old_y + radius_y*0.5;
+ tgx = actual_x + radius_x*0.5;
+ tgy = actual_y ;
+
+ ax=actual_x;
+ ay=actual_y;
//transformations
if(mtx){
transformPoint2D(mtx,&tgx2,&tgy2);
if(isFirst(k1.front(),ax,ay)){
setTg1(k1.front(),k1.front()->x,k1.front()->y,tgx,tgy);
}else{
- k1.push_back(nuevoVertice (ax,ay));
+ k1.push_back(newVertex (ax,ay));
setTg1(k1.back(),k1.back()->x,k1.back()->y,tgx,tgy);
setSplit(k1.back(),TRUE);
}
}else if( large && !sweep){//rare
//this need more than one vertex
}else if( large && sweep){//circles in inkscape are made with this kind of arc
- if(actual_y==ay){//circles
- //intermediate point
- int sense=1;
- if(actual_x>ax) sense =-1;
- float in_x,in_y,in_tgx1,in_tgy1,in_tgx2,in_tgy2;
- in_x = (actual_x+ax)/2;
- in_y = actual_y - sense*radio_y;
- in_tgx1 = in_x - sense*(radio_x*0.5);
- in_tgx2 = in_x + sense*(radio_x*0.5);
- in_tgy1 = in_y;
- in_tgy2 = in_y;
- //start/end points
- tgx2=actual_x;
- tgy2=ay - sense*(radio_y*0.5);
- tgx =ax;
- tgy =ay - sense*(radio_y*0.5);
-
- actual_x=ax;
- actual_y=ay;
- //transformations
- if(mtx){
- transformPoint2D(mtx,&tgx2,&tgy2);
- transformPoint2D(mtx,&tgx ,&tgy );
- transformPoint2D(mtx,&ax,&ay);
-
- transformPoint2D(mtx,&in_tgx2,&in_tgy2);
- transformPoint2D(mtx,&in_tgx1,&in_tgy1);
- transformPoint2D(mtx,&in_x,&in_y);
- }
- //adjust
- coor2vect(&tgx2 , &tgy2);
- coor2vect(&ax , &ay );
- coor2vect(&tgx , &tgy );
-
- coor2vect(&in_tgx2 , &in_tgy2);
- coor2vect(&in_tgx1 , &in_tgy1);
- coor2vect(&in_x , &in_y );
-
- //save the last tg2
- setTg2(k1.back(),k1.back()->x,k1.back()->y,tgx2,tgy2);
- //save the intermediate point
- k1.push_back(nuevoVertice (in_x,in_y));
- setTg1(k1.back(),k1.back()->x,k1.back()->y, in_tgx1 , in_tgy1);
- setTg2(k1.back(),k1.back()->x,k1.back()->y, in_tgx2 , in_tgy2);
- setSplit(k1.back(),TRUE); //this could be changed
- //save the new point
- if(isFirst(k1.front(),ax,ay)){
- setTg1(k1.front(),k1.front()->x,k1.front()->y,tgx,tgy);
- }else{
- k1.push_back(nuevoVertice (ax,ay));
- setTg1(k1.back(),k1.back()->x,k1.back()->y,tgx,tgy);
- setSplit(k1.back(),TRUE);
- }
+ //intermediate point
+ int sense=1;
+ if(old_x>actual_x) sense =-1;
+ float in_x,in_y,in_tgx1,in_tgy1,in_tgx2,in_tgy2;
+ in_x = (old_x+actual_x)/2;
+ in_y = old_y - sense*radius_y;
+ in_tgx1 = in_x - sense*(radius_x*0.5);
+ in_tgx2 = in_x + sense*(radius_x*0.5);
+ in_tgy1 = in_y;
+ in_tgy2 = in_y;
+ //start/end points
+ tgx2=old_x;
+ tgy2=actual_y - sense*(radius_y*0.5);
+ tgx =actual_x;
+ tgy =actual_y - sense*(radius_y*0.5);
+
+ ax=actual_x;
+ ay=actual_y;
+ //transformations
+ if(mtx){
+ transformPoint2D(mtx,&tgx2,&tgy2);
+ transformPoint2D(mtx,&tgx ,&tgy );
+ transformPoint2D(mtx,&ax,&ay);
+
+ transformPoint2D(mtx,&in_tgx2,&in_tgy2);
+ transformPoint2D(mtx,&in_tgx1,&in_tgy1);
+ transformPoint2D(mtx,&in_x,&in_y);
+ }
+ //adjust
+ coor2vect(&tgx2 , &tgy2);
+ coor2vect(&ax , &ay );
+ coor2vect(&tgx , &tgy );
+
+ coor2vect(&in_tgx2 , &in_tgy2);
+ coor2vect(&in_tgx1 , &in_tgy1);
+ coor2vect(&in_x , &in_y );
+
+ //save the last tg2
+ setTg2(k1.back(),k1.back()->x,k1.back()->y,tgx2,tgy2);
+ //save the intermediate point
+ k1.push_back(newVertex (in_x,in_y));
+ setTg1(k1.back(),k1.back()->x,k1.back()->y, in_tgx1 , in_tgy1);
+ setTg2(k1.back(),k1.back()->x,k1.back()->y, in_tgx2 , in_tgy2);
+ setSplit(k1.back(),TRUE); //this could be changed
+ //save the new point
+ if(isFirst(k1.front(),ax,ay)){
+ setTg1(k1.front(),k1.front()->x,k1.front()->y,tgx,tgy);
+ }else{
+ k1.push_back(newVertex (ax,ay));
+ setTg1(k1.back(),k1.back()->x,k1.back()->y,tgx,tgy);
+ setSplit(k1.back(),TRUE);
}
}
- }else if(tokens.at(i).compare("z")==0){
- loop=true;
+ }else if(command.compare("z")==0){
+ k.push_front(newBLine(&k1, true));
+ k1.clear();
+ if (i<tokens.size() && tokens.at(i).compare("M")!=0 && tokens.at(i).compare("m")!=0) {
+ //starting a new path, but not with a moveto
+ actual_x=init_x;
+ actual_y=init_y;
+ ax=actual_x;
+ ay=actual_y;
+ //operate and save
+ if(mtx) transformPoint2D(mtx,&ax,&ay);
+ coor2vect(&ax,&ay);
+ k1.push_back(newVertex (ax,ay)); //first element
+ setSplit(k1.back(),TRUE);
+ }
+ i--; //decrement i to balance "i++" at command change
}else{
- std::cout<<"don't supported: "<<tokens.at(i)<<std::endl;
+ std::cout<<"unsupported path token: "<<tokens.at(i)<<std::endl;
}
}
- if(!k1.empty())
- k.push_front(k1); //last element
+ if(!k1.empty()) {
+ k.push_front(newBLine(&k1, false)); //last element
+ }
return k;
}
+/* === EFFECTS PARSERS ===================================================== */
+
+void
+Svg_parser::parser_effects(const xmlpp::Element* /*nodeElement*/,xmlpp::Element* root,String /*parent_style*/,Matrix* mtx){
+ build_transform(root, mtx);
+}
+
+/* === DEFS PARSERS ======================================================== */
+
void
Svg_parser::parser_defs(const xmlpp::Node* node){
const xmlpp::ContentNode* nodeContent = dynamic_cast<const xmlpp::ContentNode*>(node);
}
}
}
+
+/* === BUILDS ============================================================== */
+
void
-Svg_parser::AdjustPointUrl(){
-/*
- if(!lg.empty()){//linealgradient
- std::list<LinearGradient*>::iterator aux=lg.begin();
- while(aux!=lg.end()){
- LinearGradient* auxlg=*aux;
- coor2vect (&auxlg->x1,&auxlg->y1);
- coor2vect (&auxlg->x2,&auxlg->y2);
- aux++;
- }
+Svg_parser::build_transform(xmlpp::Element* root,Matrix* mtx){
+ if (mtx) {
+ xmlpp::Element *child_transform=root->add_child("layer");
+ child_transform->set_attribute("type","warp");
+ child_transform->set_attribute("active","true");
+ child_transform->set_attribute("version","0.1");
+ child_transform->set_attribute("desc","Transform");
+
+ float x,y;
+ x=100;y=100;coor2vect(&x,&y);
+ build_vector (child_transform->add_child("param"),"src_tl",x,y);
+
+ x=200;y=200;coor2vect(&x,&y);
+ build_vector (child_transform->add_child("param"),"src_br",x,y);
+
+
+ x=100;y=100;
+ transformPoint2D(mtx,&x,&y);coor2vect(&x,&y);
+ build_vector (child_transform->add_child("param"),"dest_tl",x,y);
+
+ x=200;y=100;
+ transformPoint2D(mtx,&x,&y);coor2vect(&x,&y);
+ build_vector (child_transform->add_child("param"),"dest_tr",x,y);
+
+ x=200;y=200;
+ transformPoint2D(mtx,&x,&y);coor2vect(&x,&y);
+ build_vector (child_transform->add_child("param"),"dest_br",x,y);
+
+ x=100;y=200;
+ transformPoint2D(mtx,&x,&y);coor2vect(&x,&y);
+ build_vector (child_transform->add_child("param"),"dest_bl",x,y);
+
+ build_param (child_transform->add_child("param"),"clip","bool","false");
+ build_param (child_transform->add_child("param"),"horizon","real","4.0");
}
- if(!rg.empty()){//radialgradient
- std::list<RadialGradient*>::iterator aux=rg.begin();
- while(aux!=rg.end()){
- RadialGradient* auxrg=*aux;
- coor2vect (&auxrg->cx,&auxrg->cy);
- auxrg->r= auxrg->r/kux;
- aux++;
- }
- }
-*/
}
+
std::list<ColorStop*>*
Svg_parser::find_colorStop(String name){
if(!name.empty()){
if(lg.empty()&& rg.empty())
return NULL;
- String buscar= name;
- if(buscar.at(0)=='#') buscar.erase(0,1);
+ String find= name;
+ if(find.at(0)=='#') find.erase(0,1);
else return NULL;
std::list<LinearGradient*>::iterator aux=lg.begin();
while(aux!=lg.end()){//only find into linear gradients
- if(buscar.compare((*aux)->name)==0){
+ if(find.compare((*aux)->name)==0){
return (*aux)->stops;
}
aux++;
}
return NULL;
}
+
void
-Svg_parser::build_url(xmlpp::Element* root, String name,Matrix *mtx){
+Svg_parser::build_fill(xmlpp::Element* root, String name,Matrix *mtx){
if(!name.empty()){
- if(lg.empty()&& rg.empty())
- root->get_parent()->remove_child(root);
-
- int inicio=name.find_first_of("#")+1;
- int fin=name.find_first_of(")");
- String buscar= name.substr(inicio,fin-inicio);
- bool encontro=false;
+ int start=name.find_first_of("#")+1;
+ int end=name.find_first_of(")");
+ String find= name.substr(start,end-start);
+ bool encounter=false;
if(!lg.empty()){
std::list<LinearGradient*>::iterator aux=lg.begin();
while(aux!=lg.end()){
- if(buscar.compare((*aux)->name)==0){
+ if(find.compare((*aux)->name)==0){
build_linearGradient (root,*aux,mtx);
- encontro=true;
+ encounter=true;
}
aux++;
}
}
- if(!encontro && !rg.empty()){
+ if(!encounter && !rg.empty()){
std::list<RadialGradient*>::iterator aux=rg.begin();
while(aux!=rg.end()){
- if(buscar.compare((*aux)->name)==0){
+ if(find.compare((*aux)->name)==0){
build_radialGradient (root,*aux,mtx);
- encontro=true;
+ encounter=true;
}
aux++;
}
}
- if(!encontro)
- root->get_parent()->remove_child(root);
- }else{
- root->get_parent()->remove_child(root);
}
}
void
void
Svg_parser::build_linearGradient(xmlpp::Element* root,LinearGradient* data,Matrix* mtx){
if(data){
- root->set_attribute("type","linear_gradient");
- root->set_attribute("active","true");
- root->set_attribute("desc","Gradient004");
- build_param (root->add_child("param"),"z_depth","real","0");
- build_param (root->add_child("param"),"amount","real","1");
+ xmlpp::Element* gradient=root->add_child("layer");
+
+ gradient->set_attribute("type","linear_gradient");
+ gradient->set_attribute("active","true");
+ gradient->set_attribute("desc",data->name);
+ build_param (gradient->add_child("param"),"z_depth","real","0");
+ build_param (gradient->add_child("param"),"amount","real","1");
//straight onto
- build_param (root->add_child("param"),"blend_method","integer","21");
+ build_param (gradient->add_child("param"),"blend_method","integer","21");
float x1,y1,x2,y2;
x1=data->x1;
y1=data->y1;
x2=data->x2;
y2=data->y2;
- if(mtx){
- transformPoint2D(mtx,&x1,&y1);
- transformPoint2D(mtx,&x2,&y2);
+
+
+ if (mtx || data->transform){
+ Matrix *mtx2=NULL;
+ if (mtx && data->transform){
+ composeMatrix(&mtx2,mtx,data->transform);
+ }else if (mtx){
+ mtx2=mtx;
+ }else if (data->transform){
+ mtx2=data->transform;
+ }
+ //matrix transforms the gradient as a whole
+ //it does not preserve angles, so we cant' simply transform both points
+ float x3, y3, k;
+ //set point (x3,y3) on the same gradient line as (x2,y2)
+ //the gradient line is perpendicular to (x1,y1)(x2,y2)
+ x3=x2+(y2-y1);
+ y3=y2-(x2-x1);
+ //transform everything
+ transformPoint2D(mtx2,&x1,&y1);
+ transformPoint2D(mtx2,&x2,&y2);
+ transformPoint2D(mtx2,&x3,&y3);
+
+ if (x2!=x3 && y2!=y3) {//divide by zero check
+
+ //set k as slope between (x2,y2) and (x3,y3)
+ //k is the slope of gradient lines post-transformation
+ k=(y3-y2)/(x3-x2);
+ //set point (x2,y2) on the gradient line passing through (x3,y3)
+ //so that the line (x1,y1)(x2,y2) is perpendicular to (x2,y2)(x3,y3)
+ x2= (x3*k+x1/k+y1-y3)/(k+(1/k));
+ y2= k*(x2-x3)+y3;
+ } else if (x2==x3 && y2!=y3) {
+ y2=y1;
+ } else if (x2!=x3 && y2==y3) {
+ x2=x1;
+ } else {
+ std::cout<<"SVG Import warning: gradient points equal each other"<<std::endl;
+ }
}
+
coor2vect (&x1,&y1);
coor2vect (&x2,&y2);
- build_vector (root->add_child("param"),"p1",x1,y1);
- build_vector (root->add_child("param"),"p2",x2,y2);
+ build_vector (gradient->add_child("param"),"p1",x1,y1);
+ build_vector (gradient->add_child("param"),"p2",x2,y2);
//gradient link
- xmlpp::Element *child=root->add_child("param");
- child->set_attribute("name","gradient");
- build_stop_color (child->add_child("gradient"),data->stops);
- build_param (root->add_child("param"),"loop","bool","false");
- build_param (root->add_child("param"),"zigzag","bool","false");
+ xmlpp::Element *child_stops=gradient->add_child("param");
+ child_stops->set_attribute("name","gradient");
+ child_stops->set_attribute("guid",GUID::hasher(data->name).get_string());
+ build_stop_color (child_stops->add_child("gradient"),data->stops);
+ build_param (gradient->add_child("param"),"loop","bool","false");
+ build_param (gradient->add_child("param"),"zigzag","bool","false");
}
}
void
Svg_parser::build_radialGradient(xmlpp::Element* root,RadialGradient* data,Matrix* mtx){
-//not completed
if(data){
- root->set_attribute("type","radial_gradient");
- root->set_attribute("active","true");
- build_param (root->add_child("param"),"z_depth","real","0");
- build_param (root->add_child("param"),"amount","real","1");
- //straight onto
- build_param (root->add_child("param"),"blend_method","integer","21");
+ xmlpp::Element* gradient;
+
+ if (mtx || data->transform) {
+ xmlpp::Element* layer=root->add_child("layer");
+
+ layer->set_attribute("type","PasteCanvas");
+ layer->set_attribute("active","true");
+ layer->set_attribute("version","0.1");
+ layer->set_attribute("desc",data->name);
+ build_param (layer->add_child("param"),"z_depth","real","0");
+ build_param (layer->add_child("param"),"amount","real","1");
+ build_param (layer->add_child("param"),"blend_method","integer","21"); //straight onto
+ build_vector (layer->add_child("param"),"origin",0,0);
+ xmlpp::Element *child=layer->add_child("param");
+ child->set_attribute("name","canvas");
+ xmlpp::Element* child_layer=child->add_child("canvas");
+
+ gradient=child_layer->add_child("layer");
+ gradient->set_attribute("desc",data->name);
+ build_param (gradient->add_child("param"),"blend_method","integer","0"); //composite
+ Matrix *mtx2=NULL;
+ if (mtx && data->transform){
+ composeMatrix(&mtx2,mtx,data->transform);
+ }else if (mtx){
+ mtx2=mtx;
+ }else if (data->transform){
+ mtx2=data->transform;
+ }
+ build_transform(child_layer,mtx2);
+
+ }else {
+ gradient=root->add_child("layer");
+ gradient->set_attribute("desc",data->name);
+ build_param (gradient->add_child("param"),"blend_method","integer","21"); //straight onto
+ }
+
+ gradient->set_attribute("type","radial_gradient");
+ gradient->set_attribute("active","true");
+ build_param (gradient->add_child("param"),"z_depth","real","0");
+ build_param (gradient->add_child("param"),"amount","real","1");
//gradient link
- xmlpp::Element *child=root->add_child("param");
- child->set_attribute("name","gradient");
- build_stop_color (child->add_child("gradient"),data->stops);
- //here the center point and radio
+ xmlpp::Element *child_stops=gradient->add_child("param");
+ child_stops->set_attribute("name","gradient");
+ child_stops->set_attribute("guid",GUID::hasher(data->name).get_string());
+ build_stop_color (child_stops->add_child("gradient"),data->stops);
+
+ //here the center point and radius
float cx=data->cx;
float cy=data->cy;
float r =data->r;
- //transform
- if(mtx){
- transformPoint2D(mtx,&cx,&cy);
- }
+
//adjust
coor2vect (&cx,&cy);
r=r/kux;
- build_vector (root->add_child("param"),"center",cx,cy);
- build_param (root->add_child("param"),"radius","real",r);
+ build_vector (gradient->add_child("param"),"center",cx,cy);
+ build_param (gradient->add_child("param"),"radius","real",r);
- build_param (root->add_child("param"),"loop","bool","false");
- build_param (root->add_child("param"),"zigzag","bool","false");
+ build_param (gradient->add_child("param"),"loop","bool","false");
+ build_param (gradient->add_child("param"),"zigzag","bool","false");
}
}
float x2 =atof(nodeElement->get_attribute_value("x2").data());
float y2 =atof(nodeElement->get_attribute_value("y2").data());
Glib::ustring link =nodeElement->get_attribute_value("href");
+ Glib::ustring transform =nodeElement->get_attribute_value("gradientTransform");
+
+ //resolve transformations
+ Matrix* mtx=NULL;
+ if(!transform.empty())
+ mtx=parser_transform (transform);
std::list<ColorStop*> *stops;
if(!link.empty()){
}
}
if(stops)
- lg.push_back(newLinearGradient(id,x1,y1,x2,y2,stops));
+ lg.push_back(newLinearGradient(id,x1,y1,x2,y2,stops,mtx));
}
}
Glib::ustring id =nodeElement->get_attribute_value("id");
float cx =atof(nodeElement->get_attribute_value("cx").data());
float cy =atof(nodeElement->get_attribute_value("cy").data());
+ float fx =atof(nodeElement->get_attribute_value("fx").data());
+ float fy =atof(nodeElement->get_attribute_value("fy").data());
float r =atof(nodeElement->get_attribute_value("r").data());
Glib::ustring link =nodeElement->get_attribute_value("href");//basic
+ Glib::ustring transform =nodeElement->get_attribute_value("gradientTransform");
+
+ if (cx!=fx || cy!=fy)
+ std::cout<<"SVG Parser: ignoring focus attributes for radial gradient";
+
+ //resolve transformations
+ Matrix* mtx=NULL;
+ if(!transform.empty())
+ mtx=parser_transform (transform);
+
std::list<ColorStop*> *stops=NULL;
if(!link.empty()){
//inkscape always use link, i dont need parser stops here, but it's posible
stops=find_colorStop (link);
}
if(stops)
- rg.push_back(newRadialGradient(id,cx,cy,r,stops));
+ rg.push_back(newRadialGradient(id,cx,cy,r,stops,mtx));
}
}
}
LinearGradient*
-Svg_parser::newLinearGradient(String name,float x1,float y1, float x2,float y2,std::list<ColorStop*> *stops){
+Svg_parser::newLinearGradient(String name,float x1,float y1, float x2,float y2,std::list<ColorStop*> *stops, Matrix* transform){
LinearGradient* data;
data=(LinearGradient*)malloc(sizeof(LinearGradient));
sprintf(data->name,"%s",name.data());
data->x2=x2;
data->y2=y2;
data->stops=stops;
+ data->transform=transform;
return data;
}
RadialGradient*
-Svg_parser::newRadialGradient(String name,float cx,float cy,float r,std::list<ColorStop*> *stops){
+Svg_parser::newRadialGradient(String name,float cx,float cy,float r,std::list<ColorStop*> *stops, Matrix* transform){
RadialGradient* data;
data=(RadialGradient*)malloc(sizeof(RadialGradient));
sprintf(data->name,"%s",name.data());
data->cy=cy;
data->r=r;
data->stops=stops;
+ data->transform=transform;
+ return data;
+}
+
+BLine*
+Svg_parser::newBLine(std::list<Vertex*> *points,bool loop){
+ BLine* data;
+ data=(BLine*)malloc(sizeof(BLine));
+ //sprintf(data->name,"%s",name.data());
+ data->points=new std::list<Vertex*> (*points);
+ data->loop=loop;
+ data->bline_id=new String(new_guid());
+ data->offset_id=new String(new_guid());
return data;
}
-//builds
void
Svg_parser::build_gamma(xmlpp::Element* root,float gamma){
root->set_attribute("type","colorcorrect");
root->set_attribute("desc","Gamma");
build_real (root->add_child("param"),"gamma",gamma);
}
-Matrix*
-Svg_parser::build_transform(const String transform){
- Matrix* a=NULL;
- String tf(transform);
- removeIntoS(&tf);
- std::vector<String> tokens=tokenize(tf," ");
- std::vector<String>::iterator aux=tokens.begin();
- while(aux!=tokens.end()){
- if((*aux).compare(0,9,"translate")==0){
- float dx,dy;
- int inicio,fin;
- inicio =(*aux).find_first_of("(")+1;
- fin =(*aux).find_first_of(",");
- dx =atof((*aux).substr(inicio,fin-inicio).data());
- inicio =(*aux).find_first_of(",")+1;
- fin =(*aux).size()-1;
- dy =atof((*aux).substr(inicio,fin-inicio).data());
- if(matrixVacia(a))
- a=newMatrix(1,0,0,1,dx,dy);
- else
- multiplyMatrix(&a,newMatrix(1,0,0,1,dx,dy));
- }else if((*aux).compare(0,5,"scale")==0){
- if(matrixVacia(a))
- a=newMatrix(1,0,0,1,0,0);
- }else if((*aux).compare(0,6,"rotate")==0){
- float angle,seno,coseno;
- int inicio,fin;
- inicio =(*aux).find_first_of("(")+1;
- fin =(*aux).size()-1;
- angle=getRadian (atof((*aux).substr(inicio,fin-inicio).data()));
- seno =sin(angle);
- coseno =cos(angle);
- if(matrixVacia(a))
- a=newMatrix(coseno,seno,-1*seno,coseno,0,0);
- else
- multiplyMatrix(&a,newMatrix(coseno,seno,-1*seno,coseno,0,0));
- }else if((*aux).compare(0,6,"matrix")==0){
- int inicio =(*aux).find_first_of('(')+1;
- int fin =(*aux).find_first_of(')');
- if(matrixVacia(a))
- a=newMatrix((*aux).substr(inicio,fin-inicio));
- else
- multiplyMatrix(&a,newMatrix((*aux).substr(inicio,fin-inicio)));
- }else{
- a=newMatrix(1,0,0,1,0,0);
- }
- aux++;
- }
- return a;
-}
void
Svg_parser::build_translate(xmlpp::Element* root,float dx,float dy){
build_real (root->add_child("param"),"amount",angle);
}
void
-Svg_parser::build_points(xmlpp::Element* root,std::list<Vertice*> p){
+Svg_parser::build_points(xmlpp::Element* root,std::list<Vertex*> p){
root->set_attribute("name","vector_list");
xmlpp::Element *child=root->add_child("dynamic_list");
child->set_attribute("type","vector");
- std::list<Vertice*>::iterator aux = p.begin();
+ std::list<Vertex*>::iterator aux = p.begin();
while(aux!=p.end()){
xmlpp::Element *child_entry=child->add_child("entry");
xmlpp::Element *child_vector=child_entry->add_child("vector");
}
}
void
-Svg_parser::build_vertice(xmlpp::Element* root , Vertice *p){
+Svg_parser::build_vertex(xmlpp::Element* root , Vertex *p){
xmlpp::Element *child_comp=root->add_child("composite");
child_comp->set_attribute("type","bline_point");
build_vector (child_comp->add_child("param"),"point",p->x,p->y);
build_param (child_comp->add_child("origin"),"","real","0.5000000000");
if(p->split) build_param (child_comp->add_child("split"),"","bool","true");
else build_param (child_comp->add_child("split"),"","bool","false");
- //tangente 1
+ //tangent 1
xmlpp::Element *child_t1=child_comp->add_child("t1");
xmlpp::Element *child_rc=child_t1->add_child("radial_composite");
child_rc->set_attribute("type","vector");
- build_param (child_rc->add_child("radius"),"","real",p->radio1);
+ build_param (child_rc->add_child("radius"),"","real",p->radius1);
build_param (child_rc->add_child("theta"),"","angle",p->angle1);
- //tangente 2
+ //tangent 2
xmlpp::Element *child_t2=child_comp->add_child("t2");
xmlpp::Element *child_rc2=child_t2->add_child("radial_composite");
child_rc2->set_attribute("type","vector");
- build_param (child_rc2->add_child("radius"),"","real",p->radio2);
+ build_param (child_rc2->add_child("radius"),"","real",p->radius2);
build_param (child_rc2->add_child("theta"),"","angle",p->angle2);
}
void
-Svg_parser::build_bline(xmlpp::Element* root,std::list<Vertice*> p,bool loop,String blineguid){
+Svg_parser::build_bline(xmlpp::Element* root,std::list<Vertex*> p,bool loop,String blineguid){
root->set_attribute("name","bline");
xmlpp::Element *child=root->add_child("bline");
child->set_attribute("type","bline_point");
else
child->set_attribute("loop","false");
if(!blineguid.empty()) child->set_attribute("guid",blineguid);
- std::list<Vertice*>::iterator aux = p.begin();
+ std::list<Vertex*>::iterator aux = p.begin();
while(aux!=p.end()){
- if(*aux) build_vertice (child->add_child("entry"),*aux);
+ if(*aux) build_vertex (child->add_child("entry"),*aux);
aux++;
}
}
}
xmlpp::Element*
-Svg_parser::nodeStartBasicLayer(xmlpp::Element* root){
+Svg_parser::nodeStartBasicLayer(xmlpp::Element* root, String name){
root->set_attribute("type","PasteCanvas");
root->set_attribute("active","true");
root->set_attribute("version","0.1");
- root->set_attribute("desc","Composite");
+ root->set_attribute("desc",name);
build_param (root->add_child("param"),"z_depth","real","0");
build_param (root->add_child("param"),"amount","real","1");
build_param (root->add_child("param"),"blend_method","integer","0");
return child->add_child("canvas");
}
-//metodos extras
+/* === COORDINATES & TRANSFORMATIONS ======================================= */
void
Svg_parser::coor2vect(float *x,float *y){
float sx, sy;
}
void
-Svg_parser::setTg1(Vertice *p,float p1x,float p1y,float p2x,float p2y){
+Svg_parser::setTg1(Vertex *p,float p1x,float p1y,float p2x,float p2y){
float rd=0,ag=0;
float d1x,d1y,d2x,d2y,dx,dy;
d1x=p1x*60;
ag=PI;
}
ag= (ag*180)/PI;
- p->radio1=rd;
+ p->radius1=rd;
p->angle1=ag;
}
void
-Svg_parser::setTg2(Vertice* p,float p1x,float p1y,float p2x,float p2y){
+Svg_parser::setTg2(Vertex* p,float p1x,float p1y,float p2x,float p2y){
float rd=0,ag=0;
float d1x,d1y,d2x,d2y,dx,dy;
d1x=p1x*60;
rd=sqrt(dx*dx + dy*dy);
if(dx>0 && dy>0){
ag=PI + atan(dy/dx);
- // printf("caso 180-270\n");
+ // printf("case 180-270\n");
}else if(dx>0 && dy<0){
ag=PI + atan(dy/dx);
- // printf("caso 90-180\n");
+ // printf("case 90-180\n");
}else if(dx<0 && dy<0){
ag=atan(dy/dx);
- // printf("caso 0-90\n");
+ // printf("case 0-90\n");
}else if(dx<0 && dy>0){
ag= 2*PI+atan(dy/dx);
- // printf("caso 270-360\n");
+ // printf("case 270-360\n");
}else if(dx==0 && dy>0){
ag=-1*PI/2;
}else if(dx==0 && dy<0){
}
ag= (ag*180)/PI;
ag=ag-180;
- p->radio2=rd;
+ p->radius2=rd;
p->angle2=ag;
}
void
-Svg_parser::setSplit(Vertice* p,bool val){
+Svg_parser::setSplit(Vertex* p,bool val){
if(p!=NULL){
p->split=val;
}
}
int
-Svg_parser::isFirst(Vertice* nodo,float a, float b){
+Svg_parser::isFirst(Vertex* nodo,float a, float b){
if(nodo->x==a && nodo->y==b)
return 1;
return 0;
}
-Vertice*
-Svg_parser::nuevoVertice(float x,float y){
- Vertice* nuevo;
- nuevo=(Vertice*)malloc(sizeof(Vertice));
- nuevo->x=x;
- nuevo->y=y;
- nuevo->radio1=nuevo->radio2=nuevo->angle1=nuevo->angle2=0;
- return nuevo;
+Vertex*
+Svg_parser::newVertex(float x,float y){
+ Vertex* vert;
+ vert=(Vertex*)malloc(sizeof(Vertex));
+ vert->x=x;
+ vert->y=y;
+ vert->radius1=vert->radius2=vert->angle1=vert->angle2=0;
+ return vert;
+}
+
+//matrices
+Matrix*
+Svg_parser::parser_transform(const String transform){
+ Matrix* a=NULL;
+ String tf(transform);
+ removeIntoS(&tf);
+ std::vector<String> tokens=tokenize(tf," ");
+ std::vector<String>::iterator aux=tokens.begin();
+ while(aux!=tokens.end()){
+ if((*aux).compare(0,9,"translate")==0){
+ float dx,dy;
+ int start,end;
+ start =(*aux).find_first_of("(")+1;
+ end =(*aux).find_first_of(",");
+ dx =atof((*aux).substr(start,end-start).data());
+ start =(*aux).find_first_of(",")+1;
+ end =(*aux).size()-1;
+ dy =atof((*aux).substr(start,end-start).data());
+ if(matrixIsNull(a))
+ a=newMatrix(1,0,0,1,dx,dy);
+ else
+ multiplyMatrix(&a,newMatrix(1,0,0,1,dx,dy));
+ }else if((*aux).compare(0,5,"scale")==0){
+ if(matrixIsNull(a))
+ a=newMatrix(1,0,0,1,0,0);
+ }else if((*aux).compare(0,6,"rotate")==0){
+ float angle,seno,coseno;
+ int start,end;
+ start =(*aux).find_first_of("(")+1;
+ end =(*aux).size()-1;
+ angle=getRadian (atof((*aux).substr(start,end-start).data()));
+ seno =sin(angle);
+ coseno =cos(angle);
+ if(matrixIsNull(a))
+ a=newMatrix(coseno,seno,-1*seno,coseno,0,0);
+ else
+ multiplyMatrix(&a,newMatrix(coseno,seno,-1*seno,coseno,0,0));
+ }else if((*aux).compare(0,6,"matrix")==0){
+ int start =(*aux).find_first_of('(')+1;
+ int end =(*aux).find_first_of(')');
+ if(matrixIsNull(a))
+ a=newMatrix((*aux).substr(start,end-start));
+ else
+ multiplyMatrix(&a,newMatrix((*aux).substr(start,end-start)));
+ }else{
+ a=newMatrix(1,0,0,1,0,0);
+ }
+ aux++;
+ }
+ return a;
+}
+
+Matrix*
+Svg_parser::newMatrix(Matrix *a){
+ Matrix* data;
+ data=(Matrix*)malloc(sizeof(Matrix));
+ data->a=a->a; data->b=a->b; data->c=a->c;
+ data->d=a->d; data->e=a->e; data->f=a->f;
+ return data;
+}
+Matrix*
+Svg_parser::newMatrix(float a,float b,float c,float d,float e,float f){
+ Matrix* data;
+ data=(Matrix*)malloc(sizeof(Matrix));
+ data->a=a; data->b=b; data->c=c;
+ data->d=d; data->e=e; data->f=f;
+ return data;
+}
+Matrix*
+Svg_parser::newMatrix(const String mvector){
+ if(!mvector.empty()){
+ std::vector<String> tokens=tokenize(mvector,",");
+ if(tokens.size()!=6) return newMatrix(1,0,0,1,0,0);
+ Matrix* data=(Matrix*)malloc(sizeof(Matrix));
+ data->a=atof(tokens.at(0).data());
+ data->b=atof(tokens.at(1).data());
+ data->c=atof(tokens.at(2).data());
+ data->d=atof(tokens.at(3).data());
+ data->e=atof(tokens.at(4).data());
+ data->f=atof(tokens.at(5).data());
+ return data;
+ }else{
+ return newMatrix(1,0,0,1,0,0);
+ }
+}
+void
+Svg_parser::transformPoint2D(Matrix *mtx,float *a,float *b){
+ float auxa,auxb;
+ auxa=0;
+ auxb=0;
+ auxa= (*a)*(mtx->a) + (*b)*(mtx->c) + (mtx->e);
+ auxb= (*a)*(mtx->b) + (*b)*(mtx->d) + (mtx->f);
+ *a=auxa;
+ *b=auxb;
+ return;
+}
+void
+Svg_parser::composeMatrix(Matrix **mtx,Matrix* mtx1,Matrix* mtx2){
+ Matrix* aux=newMatrix(0,0,0,0,0,0);
+ aux->a=(mtx1->a)*(mtx2->a)+(mtx1->c)*(mtx2->b);
+ aux->b=(mtx1->b)*(mtx2->a)+(mtx1->d)*(mtx2->b);
+ aux->c=(mtx1->a)*(mtx2->c)+(mtx1->c)*(mtx2->d);
+ aux->d=(mtx1->b)*(mtx2->c)+(mtx1->d)*(mtx2->d);
+ aux->e=(mtx1->a)*(mtx2->e)+(mtx1->c)*(mtx2->f)+(mtx1->e);
+ aux->f=(mtx1->b)*(mtx2->e)+(mtx1->d)*(mtx2->f)+(mtx1->f);
+ *mtx=aux;
+}
+void
+Svg_parser::multiplyMatrix(Matrix **mtx1,Matrix *mtx2){
+ Matrix* aux=newMatrix(0,0,0,0,0,0);
+ aux->a=((*mtx1)->a)*(mtx2->a)+((*mtx1)->c)*(mtx2->b);
+ aux->b=((*mtx1)->b)*(mtx2->a)+((*mtx1)->d)*(mtx2->b);
+ aux->c=((*mtx1)->a)*(mtx2->c)+((*mtx1)->c)*(mtx2->d);
+ aux->d=((*mtx1)->b)*(mtx2->c)+((*mtx1)->d)*(mtx2->d);
+ aux->e=((*mtx1)->a)*(mtx2->e)+((*mtx1)->c)*(mtx2->f)+((*mtx1)->e);
+ aux->f=((*mtx1)->b)*(mtx2->e)+((*mtx1)->d)*(mtx2->f)+((*mtx1)->f);
+ (*mtx1)->a=aux->a;
+ (*mtx1)->b=aux->b;
+ (*mtx1)->c=aux->c;
+ (*mtx1)->d=aux->d;
+ (*mtx1)->e=aux->e;
+ (*mtx1)->f=aux->f;
+}
+bool
+Svg_parser::matrixIsNull(Matrix *mtx){
+ if(mtx == NULL) return true;
+ return false;
}
+/* === EXTRA METHODS ======================================================= */
+
int
Svg_parser::extractSubAttribute(const String attribute, String name,String* value){
- int encontro=0;
+ int encounter=0;
if(!attribute.empty()){
String str(attribute);
removeS(&str);
std::vector<String> tokens=tokenize(str,";");
std::vector<String>::iterator aux=tokens.begin();
while(aux!=tokens.end()){
- int medio= (*aux).find_first_of(":");
- if((*aux).substr(0,medio).compare(name)==0){
- int fin=(*aux).size();
- *value=(*aux).substr(medio+1,fin-medio);
+ int mid= (*aux).find_first_of(":");
+ if((*aux).substr(0,mid).compare(name)==0){
+ int end=(*aux).size();
+ *value=(*aux).substr(mid+1,end-mid);
return 1;
}
aux++;
}
}
- return encontro;
+ return encounter;
}
String
Svg_parser::loadAttribute(String name,const String path_style,const String master_style,const String defaultVal){
return value;
}
+std::vector<String>
+Svg_parser::get_tokens_path(String path){ //mini path lexico-parser
+ std::vector<String> tokens;
+ String buffer;
+ int e=0;
+ unsigned int i=0;
+ char a;
+ while(i<path.size()){
+ a=path.at(i);
+ switch(e){
+ case 0: //initial state
+ if(a=='m'){ e=1; i++;}
+ else if(a=='c'){ e= 2; i++;}
+ else if(a=='q'){ e= 3; i++;}
+ else if(a=='t'){ e= 4; i++;}
+ else if(a=='a'){ e= 5; i++;}
+ else if(a=='l'){ e= 6; i++;}
+ else if(a=='v'){ e= 7; i++;}
+ else if(a=='h'){ e= 8; i++;}
+ else if(a=='M'){ e= 9; i++;}
+ else if(a=='C'){ e=10; i++;}
+ else if(a=='Q'){ e=11; i++;}
+ else if(a=='T'){ e=12; i++;}
+ else if(a=='A'){ e=13; i++;}
+ else if(a=='L'){ e=14; i++;}
+ else if(a=='V'){ e=15; i++;}
+ else if(a=='H'){ e=16; i++;}
+ else if(a=='z' || a=='Z'){ e=17; i++;}
+ else if(a=='-' ||a=='.'|| isdigit (a)){ e=18;}
+ else if(a==','){ e=19; i++;}
+ else if(a==' '){i++;}
+ break;
+ //relative
+ case 1 : tokens.push_back("m"); e=0; break;//move
+ case 2 : tokens.push_back("c"); e=0; break;//curve
+ case 3 : tokens.push_back("q"); e=0; break;//quadratic
+ case 4 : tokens.push_back("t"); e=0; break;//smooth quadratic
+ case 5 : tokens.push_back("a"); e=0; break;//elliptic arc
+ case 6 : tokens.push_back("l"); e=0; break;//line to
+ case 7 : tokens.push_back("v"); e=0; break;//vertical
+ case 8 : tokens.push_back("h"); e=0; break;//horizontal
+ //absolute
+ case 9 : tokens.push_back("M"); e=0; break;
+ case 10: tokens.push_back("C"); e=0; break;
+ case 11: tokens.push_back("Q"); e=0; break;
+ case 12: tokens.push_back("T"); e=0; break;
+ case 13: tokens.push_back("A"); e=0; break;
+ case 14: tokens.push_back("L"); e=0; break;
+ case 15: tokens.push_back("V"); e=0; break;
+ case 16: tokens.push_back("H"); e=0; break;
+
+ case 17: tokens.push_back("z"); e=0; break;//loop
+ case 18: if(a=='-'||a=='.'|| isdigit (a)){
+ buffer.append(path.substr(i,1));i++;
+ }else{
+ e=20;
+ }
+ break;
+ case 19: tokens.push_back(","); e=0; break;
+ case 20: tokens.push_back(buffer);
+ buffer.clear();
+ e=0; break;
+ default: break;
+ }
+ }
+ switch(e){//last element
+ case 1 : tokens.push_back("m"); break;
+ case 2 : tokens.push_back("c"); break;
+ case 3 : tokens.push_back("q"); break;
+ case 4 : tokens.push_back("t"); break;
+ case 5 : tokens.push_back("a"); break;
+ case 6 : tokens.push_back("l"); break;
+ case 7 : tokens.push_back("v"); break;
+ case 8 : tokens.push_back("h"); break;
+ case 9 : tokens.push_back("M"); break;
+ case 10: tokens.push_back("C"); break;
+ case 11: tokens.push_back("Q"); break;
+ case 12: tokens.push_back("T"); break;
+ case 13: tokens.push_back("A"); break;
+ case 14: tokens.push_back("L"); break;
+ case 15: tokens.push_back("V"); break;
+ case 16: tokens.push_back("H"); break;
+ case 17: tokens.push_back("z"); break;
+ case 18: tokens.push_back(buffer); break;
+ case 19: tokens.push_back(","); break;
+ case 20: tokens.push_back(buffer); break;
+ default: break;
+ }
+ return tokens;
+}
+
int
Svg_parser::randomLetter(){
int a=rand()%2;
if(hex.at(0)=='#'){
return hextodec(hex.substr(1,2));
}else if(hex.compare(0,3,"rgb")==0 || hex.compare(0,3,"RGB")==0){
- int inicio=hex.find_first_of("(")+1;
- int fin =hex.find_last_of(")");
- String aux=tokenize(hex.substr(inicio,fin-inicio),",").at(0);
+ int start=hex.find_first_of("(")+1;
+ int end =hex.find_last_of(")");
+ String aux=tokenize(hex.substr(start,end-start),",").at(0);
return atoi(aux.data());
}
return 0;
if(hex.at(0)=='#'){
return hextodec(hex.substr(3,2));
}else if(hex.compare(0,3,"rgb")==0 || hex.compare(0,3,"RGB")==0){
- int inicio=hex.find_first_of("(")+1;
- int fin =hex.find_last_of(")");
- String aux=tokenize(hex.substr(inicio,fin-inicio),",").at(1);
+ int start=hex.find_first_of("(")+1;
+ int end =hex.find_last_of(")");
+ String aux=tokenize(hex.substr(start,end-start),",").at(1);
return atoi(aux.data());
}
return 0;
if(hex.at(0)=='#'){
return hextodec(hex.substr(5,2));
}else if(hex.compare(0,3,"rgb")==0 || hex.compare(0,3,"RGB")==0){
- int inicio=hex.find_first_of("(")+1;
- int fin =hex.find_last_of(")");
- String aux=tokenize(hex.substr(inicio,fin-inicio),",").at(2);
+ int start=hex.find_first_of("(")+1;
+ int end =hex.find_last_of(")");
+ String aux=tokenize(hex.substr(start,end-start),",").at(2);
return atoi(aux.data());
}
return 0;
}
return af;
}
-//matrix operations
-Matrix*
-Svg_parser::newMatrix(Matrix *a){
- Matrix* data;
- data=(Matrix*)malloc(sizeof(Matrix));
- data->a=a->a; data->b=a->b; data->c=a->c;
- data->d=a->d; data->e=a->e; data->f=a->f;
- return data;
-}
-Matrix*
-Svg_parser::newMatrix(float a,float b,float c,float d,float e,float f){
- Matrix* data;
- data=(Matrix*)malloc(sizeof(Matrix));
- data->a=a; data->b=b; data->c=c;
- data->d=d; data->e=e; data->f=f;
- return data;
-}
-Matrix*
-Svg_parser::newMatrix(const String mvector){
- if(!mvector.empty()){
- Matrix* data=(Matrix*)malloc(sizeof(Matrix));
- std::vector<String> tokens=tokenize(mvector,",");
- if(tokens.size()!=6) return newMatrix(1,0,0,1,0,0);
- data->a=atof(tokens.at(0).data());
- data->b=atof(tokens.at(1).data());
- data->c=atof(tokens.at(2).data());
- data->d=atof(tokens.at(3).data());
- data->e=atof(tokens.at(4).data());
- data->f=atof(tokens.at(5).data());
- return data;
- }else{
- return newMatrix(1,0,0,1,0,0);
- }
-}
-void
-Svg_parser::transformPoint2D(Matrix *mtx,float *a,float *b){
- float auxa,auxb;
- auxa=0;
- auxb=0;
- auxa= (*a)*(mtx->a) + (*b)*(mtx->c) + (mtx->e);
- auxb= (*a)*(mtx->b) + (*b)*(mtx->d) + (mtx->f);
- *a=auxa;
- *b=auxb;
- return;
-}
-void
-Svg_parser::composeMatrix(Matrix **mtx,Matrix* mtx1,Matrix* mtx2){
- Matrix* aux=newMatrix(0,0,0,0,0,0);
- aux->a=(mtx1->a)*(mtx2->a)+(mtx1->c)*(mtx2->b);
- aux->b=(mtx1->b)*(mtx2->a)+(mtx1->d)*(mtx2->b);
- aux->c=(mtx1->a)*(mtx2->c)+(mtx1->c)*(mtx2->d);
- aux->d=(mtx1->b)*(mtx2->c)+(mtx1->d)*(mtx2->d);
- aux->e=(mtx1->a)*(mtx2->e)+(mtx1->c)*(mtx2->f)+(mtx1->e);
- aux->f=(mtx1->b)*(mtx2->e)+(mtx1->d)*(mtx2->f)+(mtx1->f);
- *mtx=aux;
-}
-void
-Svg_parser::multiplyMatrix(Matrix **mtx1,Matrix *mtx2){
- Matrix* aux=newMatrix(0,0,0,0,0,0);
- aux->a=((*mtx1)->a)*(mtx2->a)+((*mtx1)->c)*(mtx2->b);
- aux->b=((*mtx1)->b)*(mtx2->a)+((*mtx1)->d)*(mtx2->b);
- aux->c=((*mtx1)->a)*(mtx2->c)+((*mtx1)->c)*(mtx2->d);
- aux->d=((*mtx1)->b)*(mtx2->c)+((*mtx1)->d)*(mtx2->d);
- aux->e=((*mtx1)->a)*(mtx2->e)+((*mtx1)->c)*(mtx2->f)+((*mtx1)->e);
- aux->f=((*mtx1)->b)*(mtx2->e)+((*mtx1)->d)*(mtx2->f)+((*mtx1)->f);
- (*mtx1)->a=aux->a;
- (*mtx1)->b=aux->b;
- (*mtx1)->c=aux->c;
- (*mtx1)->d=aux->d;
- (*mtx1)->e=aux->e;
- (*mtx1)->f=aux->f;
-}
-bool
-Svg_parser::matrixVacia(Matrix *mtx){
- if(mtx == NULL) return true;
- return false;
-}
float
Svg_parser::getRadian(float sexa){
** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
** Copyright (c) 2007, 2008 Chris Moore
** Copyright (c) 2009 Carlos A. Sosa Navarro
+** Copyright (c) 2009 Nikita Kitaev
**
** This package is free software; you can redistribute it and/or
** modify it under the terms of the GNU General Public License as
typedef struct linear_g{
char name[40];
float x1,x2,y1,y2;
- std::list<ColorStop*> *stops; //paradas de color
+ std::list<ColorStop*> *stops;
+ Matrix *transform;
}LinearGradient;
typedef struct radial_g{
char name[40];
float cx,cy;//center point
- //float fx,fy;
- //focus, i dont see it in synfig
- //if this value is omitted then will be = cx,cy
- float r; //radio radius
- std::list<ColorStop*> *stops; //paradas de color
+ //float fx,fy; //not supported by Synfig
+ float r; //radius
+ std::list<ColorStop*> *stops;
+ Matrix *transform;
}RadialGradient;
typedef struct url_t{
void* data;
}URL;
-typedef struct vertice_t{
+typedef struct Vertex_t{
float x,y;
- float radio1,angle1;
- float radio2,angle2;
+ float radius1,angle1;
+ float radius2,angle2;
bool split;
-}Vertice;
+}Vertex;
+
+typedef struct bline_t{
+ std::list<Vertex*> *points;
+ bool loop;
+ String* bline_id;
+ String* offset_id;
+}BLine;
+
class Svg_parser
{
//this is inkscape oriented in some cases
int uid;
int kux,set_canvas;
float ox,oy;
- bool loop;//aux :D
//urls
std::list<LinearGradient*> lg;
std::list<RadialGradient*> rg;
//String get_id();
//void set_id(String source);
-private: //parser bucle
+private:
+ /* === PARSERS ==================================== */
void parser_node(const xmlpp::Node* node);
//parser headers
void parser_svg(const xmlpp::Node* node);
void parser_canvas(const xmlpp::Node* node);
- //layers
- void parser_layer(const xmlpp::Node* node,xmlpp::Element* root,String parent_style,Matrix* mtx_parent);
- void parser_path(const xmlpp::Node* node,xmlpp::Element* root,String parent_style,Matrix* mtx_parent);
- void parser_polygon(const xmlpp::Node* node,xmlpp::Element* root,String parent_style,Matrix* mtx_parent);
- void parser_rect(const xmlpp::Node* node,xmlpp::Element* root,String parent_style,Matrix* mtx_parent);
- //defs
+ void parser_graphics(const xmlpp::Node* node,xmlpp::Element* root,String parent_style,Matrix* mtx_parent);
+
+ /* === LAYER PARSERS ============================== */
+ void parser_layer(const xmlpp::Node* node,xmlpp::Element* root,String parent_style,Matrix* mtx);
+ void parser_rect(const xmlpp::Element* nodeElement,xmlpp::Element* root,String fill, String fill_opacity, String opacity);
+ /* === CONVERT TO PATH PARSERS ==================== */
+ std::list<BLine *> parser_path_polygon(Glib::ustring polygon_points, Matrix* mtx);
+ std::list<BLine *> parser_path_d(String path_d,Matrix* mtx);
+
+ /* === EFFECTS PARSERS ============================ */
+ void parser_effects(const xmlpp::Element* nodeElement,xmlpp::Element* root,String parent_style,Matrix* mtx);
+
+ /* === DEFS PARSERS =============================== */
void parser_defs(const xmlpp::Node* node);
void parser_linearGradient(const xmlpp::Node* node);
void parser_radialGradient(const xmlpp::Node* node);
ColorStop* newColorStop(String color,float opacity,float pos);
- LinearGradient* newLinearGradient(String name,float x1,float y1, float x2,float y2,std::list<ColorStop*> *stops);
- RadialGradient* newRadialGradient(String name,float cx,float cy,float r,std::list<ColorStop*> *stops);
- //builds urls
- void AdjustPointUrl();
+ LinearGradient* newLinearGradient(String name,float x1,float y1, float x2,float y2,std::list<ColorStop*> *stops, Matrix* transform);
+ RadialGradient* newRadialGradient(String name,float cx,float cy,float r,std::list<ColorStop*> *stops, Matrix* transform);
+ BLine* newBLine(std::list<Vertex*> *points,bool loop);
+
+ /* === BUILDS ===================================== */
+ void build_transform(xmlpp::Element* root,Matrix* mtx);
std::list<ColorStop*>* find_colorStop(String name);
- void build_url(xmlpp::Element* root, String name,Matrix *mtx);
+ void build_fill(xmlpp::Element* root, String name,Matrix *mtx);
void build_linearGradient(xmlpp::Element* root,LinearGradient* data,Matrix* mtx);
void build_radialGradient(xmlpp::Element* root,RadialGradient* data,Matrix* mtx);
void build_stop_color(xmlpp::Element* root, std::list<ColorStop*> *stops);
void build_stop_color(xmlpp::Element* root, std::list<ColorStop*> *stops,String name);
Color adjustGamma(float r,float g,float b,float a);
- //builds
+
void build_gamma(xmlpp::Element* root,float gamma);
- Matrix* build_transform(const String transform);
void build_rotate(xmlpp::Element* root,float dx,float dy,float angle);
void build_translate(xmlpp::Element* root,float dx,float dy);
- void build_points(xmlpp::Element* root,std::list<Vertice*> p);
- void build_vertice(xmlpp::Element* root , Vertice *p);
- void build_bline(xmlpp::Element* root,std::list<Vertice*> p,bool loop,String blinegui);
+ void build_points(xmlpp::Element* root,std::list<Vertex*> p);
+ void build_vertex(xmlpp::Element* root , Vertex *p);
+ void build_bline(xmlpp::Element* root,std::list<Vertex*> p,bool loop,String blineguid);
void build_param (xmlpp::Element* root,String name,String type,String value);
void build_param (xmlpp::Element* root,String name,String type,float value);
void build_param (xmlpp::Element* root,String name,String type,int value);
void build_vector (xmlpp::Element* root,String name,float x,float y,String guid);
void build_color(xmlpp::Element* root,float r,float g,float b,float a);
xmlpp::Element* nodeStartBasicLayer(xmlpp::Element* root);
+ xmlpp::Element* nodeStartBasicLayer(xmlpp::Element* root, String name);
+
+ /* === COORDINATES & TRANSFORMATIONS ============== */
//points,etc
void coor2vect(float *x,float *y);
- void setTg2(Vertice* p,float p1x,float p1y,float p2x,float p2y);
- void setTg1(Vertice *p,float p1x,float p1y,float p2x,float p2y);
- void setSplit(Vertice* p,bool val);
- int isFirst(Vertice* nodo,float a, float b);
- Vertice* nuevoVertice(float x,float y);
+ void setTg2(Vertex* p,float p1x,float p1y,float p2x,float p2y);
+ void setTg1(Vertex *p,float p1x,float p1y,float p2x,float p2y);
+ void setSplit(Vertex* p,bool val);
+ int isFirst(Vertex* nodo,float a, float b);
+ Vertex* newVertex(float x,float y);
//matrix operations
+ Matrix* parser_transform(const String transform);
Matrix* newMatrix(float a,float b,float c,float d,float e,float f);
Matrix* newMatrix(const String mvector);
Matrix* newMatrix(Matrix *a);
void transformPoint2D(Matrix *mtx,float *a,float *b);
- bool matrixVacia(Matrix* mtx);
+ bool matrixIsNull(Matrix* mtx);
void composeMatrix(Matrix **mtx,Matrix *mtx1,Matrix *mtx2);
void multiplyMatrix(Matrix **mtx1,Matrix *mtx2);
float getRadian(float sexa);
+
+ /* === EXTRA METHODS ============================== */
+
//attributes
int extractSubAttribute(const String attribute, String name,String* value);
String loadAttribute(String name,const String path_style,const String master_style,const String subattribute,const String defaultVal);
String loadAttribute(String name,const String path_style,const String master_style,const String defaultVal);
std::vector<String> get_tokens_path(String path);
- std::list<std::list<Vertice*> > parser_path_d(String path_d,Matrix* mtx);
int randomLetter();
int getRed(String hex);
int getGreen(String hex);
int getBlue(String hex);
int hextodec(String hex);
float getDimension(const String ac);
- //funciones string
+ //string functions
void removeS(String *input);
void removeIntoS(String *input);
std::vector<String> tokenize(const String& str,const String& delimiters);
mirror_icon.sif \
navigator_icon.sif \
normal_icon.sif \
- null_icon.sif \
pastecanvas_icon.sif \
polygon_icon.sif \
real_icon.sif \
keyframe_icon.$(EXT) \
reset_colors_icon.$(EXT) \
swap_colors_icon.$(EXT) \
+ rotate_icon.$(EXT) \
+ scale_icon.$(EXT) \
smooth_move_icon.$(EXT) \
width_icon.$(EXT) \
rectangle_icon.$(EXT) \
sketch_icon.$(EXT) \
fill_icon.$(EXT) \
normal_icon.$(EXT) \
- null_icon.$(EXT) \
select_all_child_layers_icon.$(EXT) \
sif_icon.$(EXT) \
synfig_icon.$(EXT) \
+++ /dev/null
-<?xml version="1.0"?>
-<canvas version="0.1" width="128" height="128" xres="2952.755900" yres="2952.755900" view-box="-2.000000 2.000000 2.000000 -2.000000" antialias="1" fps="30.000" begin-time="0f" end-time="0f" bgcolor="0.500000 0.500000 0.500000 1.000000">
- <name>Untitled0</name>
- <layer type="PasteCanvas" active="true" version="0.1">
- <param name="z_depth">
- <real value="0.0000000000"/>
- </param>
- <param name="amount">
- <real value="1.0000000000"/>
- </param>
- <param name="blend_method">
- <integer value="0"/>
- </param>
- <param name="origin">
- <vector>
- <x>0.0000000000</x>
- <y>0.0500000007</y>
- </vector>
- </param>
- <param name="canvas" use="logo.sif#"/>
- <param name="zoom">
- <real value="0.2750000000"/>
- </param>
- <param name="time_offset">
- <time value="0f"/>
- </param>
- </layer>
- <layer type="shade" active="true" version="0.2">
- <param name="z_depth">
- <real value="0.0000000000"/>
- </param>
- <param name="amount">
- <real value="0.7500000000"/>
- </param>
- <param name="blend_method">
- <integer value="12"/>
- </param>
- <param name="color">
- <color>
- <r>0.000000</r>
- <g>0.000000</g>
- <b>0.000000</b>
- <a>1.000000</a>
- </color>
- </param>
- <param name="offset">
- <vector>
- <x>0.1000000015</x>
- <y>-0.1000000015</y>
- </vector>
- </param>
- <param name="size">
- <vector>
- <x>0.2000000030</x>
- <y>0.2000000030</y>
- </vector>
- </param>
- <param name="type">
- <integer value="1"/>
- </param>
- <param name="invert">
- <bool value="false"/>
- </param>
- </layer>
-</canvas>
--- /dev/null
+<?xml version="1.0"?>
+<canvas version="0.1" width="200" height="200" xres="2834.645752" yres="2834.645752" view-box="-3.245196 3.245196 3.245196 -3.245196" antialias="1" fps="24.000" begin-time="0f" end-time="0f" bgcolor="0.500000 0.500000 0.500000 1.000000">
+ <name>Synfig Studio Rotate Icon</name>
+ <desc>Placed in the Public Domain in 2007 by Chris Norman (pixelgeek)</desc>
+ <meta name="grid_show" content="0"/>
+ <meta name="grid_size" content="0.259616 0.259616"/>
+ <meta name="grid_snap" content="0"/>
+ <meta name="guide_show" content="1"/>
+ <meta name="guide_snap" content="0"/>
+ <meta name="onion_skin" content="0"/>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Upper rectangle shadow">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="radial_gradient" active="true" version="0.1">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="gradient">
+ <gradient>
+ <color pos="0.000000">
+ <r>0.300000</r>
+ <g>0.300000</g>
+ <b>0.300000</b>
+ <a>1.000000</a>
+ </color>
+ <color pos="1.000000">
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>0.000000</a>
+ </color>
+ </gradient>
+ </param>
+ <param name="center">
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="radius">
+ <real value="2.4078271871"/>
+ </param>
+ <param name="loop">
+ <bool value="false"/>
+ </param>
+ <param name="zigzag">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="warp" active="true" version="0.1">
+ <param name="src_tl">
+ <vector>
+ <x>-2.5961599350</x>
+ <y>2.5961599350</y>
+ </vector>
+ </param>
+ <param name="src_br">
+ <vector>
+ <x>2.6703450680</x>
+ <y>-2.1673052311</y>
+ </vector>
+ </param>
+ <param name="dest_tl">
+ <vector>
+ <x>-3.2451999187</x>
+ <y>0.8112999797</y>
+ </vector>
+ </param>
+ <param name="dest_tr">
+ <vector>
+ <x>1.7848598957</x>
+ <y>0.8112999797</y>
+ </vector>
+ </param>
+ <param name="dest_br">
+ <vector>
+ <x>2.2716398239</x>
+ <y>-0.3245199919</y>
+ </vector>
+ </param>
+ <param name="dest_bl">
+ <vector>
+ <x>-2.9206800461</x>
+ <y>-0.3245199919</y>
+ </vector>
+ </param>
+ <param name="clip">
+ <bool value="true"/>
+ </param>
+ <param name="horizon">
+ <real value="2.0000000000"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Lower rectangle shadow">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="radial_gradient" active="true" version="0.1">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="gradient">
+ <gradient>
+ <color pos="0.000000">
+ <r>0.300000</r>
+ <g>0.300000</g>
+ <b>0.300000</b>
+ <a>1.000000</a>
+ </color>
+ <color pos="1.000000">
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>0.000000</a>
+ </color>
+ </gradient>
+ </param>
+ <param name="center">
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="radius">
+ <real value="2.4078271871"/>
+ </param>
+ <param name="loop">
+ <bool value="false"/>
+ </param>
+ <param name="zigzag">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="warp" active="true" version="0.1">
+ <param name="src_tl">
+ <vector>
+ <x>-2.5961599350</x>
+ <y>2.5961599350</y>
+ </vector>
+ </param>
+ <param name="src_br">
+ <vector>
+ <x>2.6703450680</x>
+ <y>-2.1673052311</y>
+ </vector>
+ </param>
+ <param name="dest_tl">
+ <vector>
+ <x>-2.2716398239</x>
+ <y>-1.4603400230</y>
+ </vector>
+ </param>
+ <param name="dest_tr">
+ <vector>
+ <x>2.7584199905</x>
+ <y>-1.4603400230</y>
+ </vector>
+ </param>
+ <param name="dest_br">
+ <vector>
+ <x>3.2451999187</x>
+ <y>-2.5961599350</y>
+ </vector>
+ </param>
+ <param name="dest_bl">
+ <vector>
+ <x>-1.9471199512</x>
+ <y>-2.5961599350</y>
+ </vector>
+ </param>
+ <param name="clip">
+ <bool value="true"/>
+ </param>
+ <param name="horizon">
+ <real value="2.0000000000"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Upper Rectangle with gradient">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>0.4867799878</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="rectangle" active="true" version="0.2" desc="Blue Rectangle">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.065656</g>
+ <b>0.247059</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="point1">
+ <vector>
+ <x>-3.3425526619</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="point2">
+ <vector>
+ <x>0.5516827703</x>
+ <y>3.1153881550</y>
+ </vector>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="rectangle" active="true" version="0.2" desc="White Rectangle">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="point1">
+ <vector>
+ <x>-3.0829367638</x>
+ <y>0.2596156895</y>
+ </vector>
+ </param>
+ <param name="point2">
+ <vector>
+ <x>0.2920670807</x>
+ <y>2.8557724953</y>
+ </vector>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Rectangle gradient">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>-1.7848598957</x>
+ <y>1.9471199512</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas width="480" height="270" view-box="-4.000000 2.250000 4.000000 -2.250000" antialias="2">
+ <layer type="rectangle" active="true" version="0.2" desc="White Rectangle">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="point1">
+ <vector>
+ <x>-1.0384613276</x>
+ <y>-1.4278886318</y>
+ </vector>
+ </param>
+ <param name="point2">
+ <vector>
+ <x>1.8173112869</x>
+ <y>0.6490369439</y>
+ </vector>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="linear_gradient" active="true" version="0.0" desc="Gradient">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="13"/>
+ </param>
+ <param name="p1">
+ <vector>
+ <x>-1.7848600149</x>
+ <y>1.9471199512</y>
+ </vector>
+ </param>
+ <param name="p2">
+ <vector>
+ <x>2.9206800461</x>
+ <y>-4.0564999580</y>
+ </vector>
+ </param>
+ <param name="gradient">
+ <gradient>
+ <color pos="0.000000">
+ <r>0.028991</r>
+ <g>0.133209</g>
+ <b>0.374624</b>
+ <a>1.000000</a>
+ </color>
+ <color pos="1.000000">
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </gradient>
+ </param>
+ <param name="loop">
+ <bool value="false"/>
+ </param>
+ <param name="zigzag">
+ <bool value="false"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Lower Rectangle with gradient">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="rectangle" active="true" version="0.2" desc="Blue Rectangle">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.065656</g>
+ <b>0.247059</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="point1">
+ <vector>
+ <x>-1.1146180630</x>
+ <y>-2.0209679604</y>
+ </vector>
+ </param>
+ <param name="point2">
+ <vector>
+ <x>2.5569021702</x>
+ <y>0.9162484407</y>
+ </vector>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="rectangle" active="true" version="0.2" desc="White Rectangle">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="point1">
+ <vector>
+ <x>-0.8734864593</x>
+ <y>-1.7986452579</y>
+ </vector>
+ </param>
+ <param name="point2">
+ <vector>
+ <x>2.3052372932</x>
+ <y>0.6841450930</y>
+ </vector>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Rectangle gradient">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>0.1622599959</x>
+ <y>-0.3245199919</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="rectangle" active="true" version="0.2" desc="White Rectangle">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="point1">
+ <vector>
+ <x>-0.8288472295</x>
+ <y>-1.2672259808</y>
+ </vector>
+ </param>
+ <param name="point2">
+ <vector>
+ <x>1.9548872709</x>
+ <y>0.7829568982</y>
+ </vector>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="linear_gradient" active="true" version="0.0" desc="Gradient">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="13"/>
+ </param>
+ <param name="p1">
+ <vector>
+ <x>2.0723481178</x>
+ <y>-2.8204009533</y>
+ </vector>
+ </param>
+ <param name="p2">
+ <vector>
+ <x>-2.8938808441</x>
+ <y>3.8485348225</y>
+ </vector>
+ </param>
+ <param name="gradient">
+ <gradient>
+ <color pos="0.000000">
+ <r>0.028991</r>
+ <g>0.133209</g>
+ <b>0.374624</b>
+ <a>1.000000</a>
+ </color>
+ <color pos="1.000000">
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </gradient>
+ </param>
+ <param name="loop">
+ <bool value="false"/>
+ </param>
+ <param name="zigzag">
+ <bool value="false"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="rotate" active="true" version="0.1">
+ <param name="origin">
+ <vector>
+ <x>0.9735599756</x>
+ <y>-0.1622599959</y>
+ </vector>
+ </param>
+ <param name="amount">
+ <angle value="-45.000000"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Lower arrow">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="region" active="true" version="0.1" desc="Arrow Region">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector guid="05993A4BCC99F10B8F4D74AE5D68DD79">
+ <x>-4.0240430832</x>
+ <y>-2.9855804443</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="true" guid="E831D3707F7936CAE7D73D2C5B5CA16E">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.7908737659</x>
+ <y>0.8437545300</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.7788470627"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="2.7259647195"/>
+ </c0>
+ <c1>
+ <angle value="180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.7524110079</x>
+ <y>1.4927937984</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.1682705941"/>
+ </c0>
+ <c1>
+ <angle value="90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.7788470627"/>
+ </c0>
+ <c1>
+ <angle value="90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.7524110079</x>
+ <y>1.8822172880</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.7788470627"/>
+ </c0>
+ <c1>
+ <angle value="180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.1033717394</x>
+ <y>1.8822172880</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.7788470627"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.1014560791"/>
+ </c0>
+ <c1>
+ <angle value="45.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.9471199512</x>
+ <y>2.7584199905</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.9975694309"/>
+ </c0>
+ <c1>
+ <angle value="46.975098"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.4473043330"/>
+ </c0>
+ <c1>
+ <angle value="-47.726048"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.7908737659</x>
+ <y>1.8822172880</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.6521841187"/>
+ </c0>
+ <c1>
+ <angle value="-45.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.7645753250"/>
+ </c0>
+ <c1>
+ <angle value="180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.1418344975</x>
+ <y>1.8822172880</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.1418344975</x>
+ <y>1.6226016283</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.1682705941"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.7908737659</x>
+ <y>1.2331780195</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.9471176568"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.7788470627"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ </layer>
+ <layer type="shade" active="true" version="0.2">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="12"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.303279</r>
+ <g>0.295082</g>
+ <b>0.303279</b>
+ <a>0.333333</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>-0.1894220859</x>
+ <y>-0.1675494760</y>
+ </vector>
+ </param>
+ <param name="size">
+ <vector>
+ <x>0.1000007167</x>
+ <y>0.1000007167</y>
+ </vector>
+ </param>
+ <param name="type">
+ <integer value="1"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="Arrow Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.065656</g>
+ <b>0.247059</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector guid="05993A4BCC99F10B8F4D74AE5D68DD79">
+ <x>-4.0240430832</x>
+ <y>-2.9855804443</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="true" guid="E831D3707F7936CAE7D73D2C5B5CA16E">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.7908737659</x>
+ <y>0.8437545300</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.7788470627"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="2.7259647195"/>
+ </c0>
+ <c1>
+ <angle value="180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.7524110079</x>
+ <y>1.4927937984</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.1682705941"/>
+ </c0>
+ <c1>
+ <angle value="90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.7788470627"/>
+ </c0>
+ <c1>
+ <angle value="90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.7524110079</x>
+ <y>1.8822172880</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.7788470627"/>
+ </c0>
+ <c1>
+ <angle value="180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.1033717394</x>
+ <y>1.8822172880</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.7788470627"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.1014560791"/>
+ </c0>
+ <c1>
+ <angle value="45.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.9471199512</x>
+ <y>2.7584199905</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.9975694309"/>
+ </c0>
+ <c1>
+ <angle value="46.975098"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.4473043330"/>
+ </c0>
+ <c1>
+ <angle value="-47.726048"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.7908737659</x>
+ <y>1.8822172880</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.6521841187"/>
+ </c0>
+ <c1>
+ <angle value="-45.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.7645753250"/>
+ </c0>
+ <c1>
+ <angle value="180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.1418344975</x>
+ <y>1.8822172880</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.1418344975</x>
+ <y>1.6226016283</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.1682705941"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.7908737659</x>
+ <y>1.2331780195</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.9471176568"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.7788470627"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="true"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Upper Arrow">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="region" active="true" version="0.1" desc="Arrow Region">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector guid="80F6181CA1918EAE33C34EC82856397B">
+ <x>0.1622599959</x>
+ <y>-0.3245199919</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="true" guid="E3A6EF8C8CDADE2362FFDE8ABF503B65">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.1358199120</x>
+ <y>2.9206800461</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.4603399634"/>
+ </c0>
+ <c1>
+ <angle value="90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="2.7259603095"/>
+ </c0>
+ <c1>
+ <angle value="-0.000200"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.1742811203</x>
+ <y>2.4014453888</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.5576941254"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.9735599756"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.1742811203</x>
+ <y>1.8822140694</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.8233203888</x>
+ <y>1.8822140694</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.6521841187"/>
+ </c0>
+ <c1>
+ <angle value="-135.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.9795694351</x>
+ <y>1.1033670902</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.5207475048"/>
+ </c0>
+ <c1>
+ <angle value="-140.194427"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.1014560791"/>
+ </c0>
+ <c1>
+ <angle value="135.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.1358184814</x>
+ <y>1.8822140694</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.1014560791"/>
+ </c0>
+ <c1>
+ <angle value="135.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.7788470627"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.7848576307</x>
+ <y>1.8822140694</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.1947060299"/>
+ </c0>
+ <c1>
+ <angle value="90.001968"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.7848598957</x>
+ <y>2.2716398239</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894300570"/>
+ </c0>
+ <c1>
+ <angle value="89.999016"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.9735599756"/>
+ </c0>
+ <c1>
+ <angle value="90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.1358184814</x>
+ <y>2.5312533379</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.9471199512"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.4867799878"/>
+ </c0>
+ <c1>
+ <angle value="90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="Arrow Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.065656</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector guid="80F6181CA1918EAE33C34EC82856397B">
+ <x>0.1622599959</x>
+ <y>-0.3245199919</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="true" guid="E3A6EF8C8CDADE2362FFDE8ABF503B65">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.1358199120</x>
+ <y>2.9206800461</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.4603399634"/>
+ </c0>
+ <c1>
+ <angle value="90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="2.7259603095"/>
+ </c0>
+ <c1>
+ <angle value="-0.000200"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.1742811203</x>
+ <y>2.4014453888</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.5576941254"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.9735599756"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.1742811203</x>
+ <y>1.8822140694</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="-90.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>2.8233203888</x>
+ <y>1.8822140694</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.6521841187"/>
+ </c0>
+ <c1>
+ <angle value="-135.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.9795694351</x>
+ <y>1.1033670902</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.5207475048"/>
+ </c0>
+ <c1>
+ <angle value="-140.194427"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.1014560791"/>
+ </c0>
+ <c1>
+ <angle value="135.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.1358184814</x>
+ <y>1.8822140694</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.1014560791"/>
+ </c0>
+ <c1>
+ <angle value="135.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.7788470627"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.7848576307</x>
+ <y>1.8822140694</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894235314"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.1947060299"/>
+ </c0>
+ <c1>
+ <angle value="90.001968"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.7848598957</x>
+ <y>2.2716398239</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.3894300570"/>
+ </c0>
+ <c1>
+ <angle value="89.999016"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.9735599756"/>
+ </c0>
+ <c1>
+ <angle value="90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>1.1358184814</x>
+ <y>2.5312533379</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="true"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="1.9471199512"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.4867799878"/>
+ </c0>
+ <c1>
+ <angle value="90.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="true"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+</canvas>
--- /dev/null
+<?xml version="1.0"?>
+<canvas version="0.1" width="200" height="200" xres="2834.645752" yres="2834.645752" view-box="-3.245196 3.245196 3.245196 -3.245196" antialias="1" fps="24.000" begin-time="0f" end-time="0f" bgcolor="0.500000 0.500000 0.500000 1.000000">
+ <name>Synfig Studio Scale Icon</name>
+ <desc>Placed in the Public Domain in 2007 by Chris Norman (pixelgeek)</desc>
+ <meta name="grid_show" content="0"/>
+ <meta name="grid_size" content="0.259616 0.259616"/>
+ <meta name="grid_snap" content="0"/>
+ <meta name="guide_show" content="1"/>
+ <meta name="guide_snap" content="0"/>
+ <meta name="onion_skin" content="0"/>
+ <layer type="linear_gradient" active="true" version="0.0">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="p1">
+ <vector>
+ <x>-0.6717824340</x>
+ <y>8.4043684006</y>
+ </vector>
+ </param>
+ <param name="p2">
+ <vector>
+ <x>-0.4427109957</x>
+ <y>-1.6098945141</y>
+ </vector>
+ </param>
+ <param name="gradient">
+ <gradient>
+ <color pos="0.000000">
+ <r>0.064115</r>
+ <g>0.064115</g>
+ <b>0.064115</b>
+ <a>1.000000</a>
+ </color>
+ <color pos="1.000000">
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>0.000000</a>
+ </color>
+ </gradient>
+ </param>
+ <param name="loop">
+ <bool value="false"/>
+ </param>
+ <param name="zigzag">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="warp" active="true" version="0.1">
+ <param name="src_tl">
+ <vector>
+ <x>-1.1483865976</x>
+ <y>1.7675857544</y>
+ </vector>
+ </param>
+ <param name="src_br">
+ <vector>
+ <x>2.6703450680</x>
+ <y>-2.1673052311</y>
+ </vector>
+ </param>
+ <param name="dest_tl">
+ <vector>
+ <x>-1.6225999594</x>
+ <y>-2.2716398239</y>
+ </vector>
+ </param>
+ <param name="dest_tr">
+ <vector>
+ <x>2.7584199905</x>
+ <y>-2.2716398239</y>
+ </vector>
+ </param>
+ <param name="dest_br">
+ <vector>
+ <x>3.4074599743</x>
+ <y>-3.0829398632</y>
+ </vector>
+ </param>
+ <param name="dest_bl">
+ <vector>
+ <x>-1.1358199120</x>
+ <y>-3.0829398632</y>
+ </vector>
+ </param>
+ <param name="clip">
+ <bool value="true"/>
+ </param>
+ <param name="horizon">
+ <real value="2.0000000000"/>
+ </param>
+ </layer>
+ <layer type="rectangle" active="true" version="0.2" desc="Blue Rectangle">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="point1">
+ <vector>
+ <x>-1.8173098564</x>
+ <y>-2.5961568356</y>
+ </vector>
+ </param>
+ <param name="point2">
+ <vector>
+ <x>3.1153881550</x>
+ <y>1.5576940775</y>
+ </vector>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="rectangle" active="true" version="0.2" desc="White Rectangle">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="point1">
+ <vector>
+ <x>-1.5576940775</x>
+ <y>-2.3365411758</y>
+ </vector>
+ </param>
+ <param name="point2">
+ <vector>
+ <x>2.8557724953</x>
+ <y>1.2980784178</y>
+ </vector>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Rectangle gradient">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="rectangle" active="true" version="0.2" desc="White Rectangle">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="point1">
+ <vector>
+ <x>-1.2980784178</x>
+ <y>-2.0769255161</y>
+ </vector>
+ </param>
+ <param name="point2">
+ <vector>
+ <x>2.5961568356</x>
+ <y>1.0384627581</y>
+ </vector>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="linear_gradient" active="true" version="0.0" desc="Gradient">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="13"/>
+ </param>
+ <param name="p1">
+ <vector>
+ <x>-1.7848600149</x>
+ <y>1.9471199512</y>
+ </vector>
+ </param>
+ <param name="p2">
+ <vector>
+ <x>2.9206800461</x>
+ <y>-4.0564999580</y>
+ </vector>
+ </param>
+ <param name="gradient">
+ <gradient>
+ <color pos="0.000000">
+ <r>0.028991</r>
+ <g>0.133209</g>
+ <b>0.374624</b>
+ <a>1.000000</a>
+ </color>
+ <color pos="1.000000">
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </gradient>
+ </param>
+ <param name="loop">
+ <bool value="false"/>
+ </param>
+ <param name="zigzag">
+ <bool value="false"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="rectangle" active="true" version="0.2" desc="Blue Rectangle">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="point1">
+ <vector>
+ <x>-3.1153881550</x>
+ <y>0.2596156895</y>
+ </vector>
+ </param>
+ <param name="point2">
+ <vector>
+ <x>0.0000000000</x>
+ <y>2.8557724953</y>
+ </vector>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="rectangle" active="true" version="0.2" desc="White Rectangle">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="point1">
+ <vector>
+ <x>-2.8557724953</x>
+ <y>0.5192313790</y>
+ </vector>
+ </param>
+ <param name="point2">
+ <vector>
+ <x>-0.2596156895</x>
+ <y>2.5961568356</y>
+ </vector>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Rectangle gradient">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>-1.7848598957</x>
+ <y>1.9471199512</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="rectangle" active="true" version="0.2" desc="White Rectangle">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="point1">
+ <vector>
+ <x>-0.8112969995</x>
+ <y>-1.1682728529</y>
+ </vector>
+ </param>
+ <param name="point2">
+ <vector>
+ <x>1.2656285763</x>
+ <y>0.3894212246</y>
+ </vector>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="linear_gradient" active="true" version="0.0" desc="Gradient">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="13"/>
+ </param>
+ <param name="p1">
+ <vector>
+ <x>-1.7848600149</x>
+ <y>1.9471199512</y>
+ </vector>
+ </param>
+ <param name="p2">
+ <vector>
+ <x>2.9206800461</x>
+ <y>-4.0564999580</y>
+ </vector>
+ </param>
+ <param name="gradient">
+ <gradient>
+ <color pos="0.000000">
+ <r>0.028991</r>
+ <g>0.133209</g>
+ <b>0.374624</b>
+ <a>1.000000</a>
+ </color>
+ <color pos="1.000000">
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </gradient>
+ </param>
+ <param name="loop">
+ <bool value="false"/>
+ </param>
+ <param name="zigzag">
+ <bool value="false"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Vertical Dotted line">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>-2.2769572735</x>
+ <y>-1.7023979425</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>1.9471199512</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.2716398239</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>1.9471199512</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>1.9471199512</x>
+ <y>0.6490399837</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.2716398239</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>1.9471199512</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>1.9471199512</x>
+ <y>1.2980799675</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.2716398239</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>1.9471199512</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>1.9471199512</x>
+ <y>-0.6490399837</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.2716398239</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>1.9471199512</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Vertical Dotted line">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>0.9788787961</x>
+ <y>-1.5747181177</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>1.9471199512</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.2716398239</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>1.9471199512</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>1.9471199512</x>
+ <y>0.6490399837</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.2716398239</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>1.9471199512</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>1.9471199512</x>
+ <y>1.2980799675</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.2716398239</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>1.9471199512</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>1.9471199512</x>
+ <y>-0.6490399837</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.2716398239</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>1.9471199512</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="-180.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Horizontal Dotted line">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>-0.0957598835</x>
+ <y>-2.7983164787</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>2.2716398239</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.6225999594</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>1.7848598957</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.6225999594</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>1.2980799675</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.6225999594</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>0.8112999797</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.6225999594</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>0.3245199919</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.6225999594</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>-0.1622599959</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.6225999594</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="PasteCanvas" active="true" version="0.1" desc="Horizontal Dotted line">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="origin">
+ <vector>
+ <x>0.0286085363</x>
+ <y>0.0443108305</y>
+ </vector>
+ </param>
+ <param name="canvas">
+ <canvas>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>2.2716398239</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.6225999594</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>1.7848598957</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.6225999594</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>1.2980799675</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.6225999594</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>0.8112999797</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.6225999594</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>0.3245199919</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.6225999594</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ <layer type="outline" active="true" version="0.2" desc="NewBLine Outline">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>-0.1622599959</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="bline">
+ <bline type="bline_point" loop="false">
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.9471199512</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ <entry>
+ <composite type="bline_point">
+ <c1>
+ <vector>
+ <x>-1.6225999594</x>
+ <y>2.1093800068</y>
+ </vector>
+ </c1>
+ <c2>
+ <real value="1.0000000000"/>
+ </c2>
+ <c3>
+ <real value="0.5000000000"/>
+ </c3>
+ <c4>
+ <bool value="false"/>
+ </c4>
+ <c5>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c5>
+ <c6>
+ <radial_composite type="vector">
+ <c0>
+ <real value="0.0000000000"/>
+ </c0>
+ <c1>
+ <angle value="0.000000"/>
+ </c1>
+ </radial_composite>
+ </c6>
+ </composite>
+ </entry>
+ </bline>
+ </param>
+ <param name="width">
+ <real value="0.1947117657"/>
+ </param>
+ <param name="expand">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="sharp_cusps">
+ <bool value="true"/>
+ </param>
+ <param name="round_tip[0]">
+ <bool value="false"/>
+ </param>
+ <param name="round_tip[1]">
+ <bool value="false"/>
+ </param>
+ <param name="loopyness">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="homogeneous_width">
+ <bool value="true"/>
+ </param>
+ </layer>
+ </canvas>
+ </param>
+ <param name="zoom">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="time_offset">
+ <time value="0s"/>
+ </param>
+ <param name="children_lock">
+ <bool value="false"/>
+ </param>
+ </layer>
+ <layer type="polygon" active="true" version="0.1" desc="White Arrow">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>0.011238</r>
+ <g>0.064115</g>
+ <b>0.247404</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="vector_list">
+ <dynamic_list type="vector">
+ <entry>
+ <vector>
+ <x>-1.7130378485</x>
+ <y>2.0215976238</y>
+ </vector>
+ </entry>
+ <entry>
+ <vector>
+ <x>-2.0641574860</x>
+ <y>1.6385580301</y>
+ </vector>
+ </entry>
+ <entry>
+ <vector>
+ <x>0.7235190868</x>
+ <y>-0.7979990244</y>
+ </vector>
+ </entry>
+ <entry>
+ <vector>
+ <x>-0.0033114245</x>
+ <y>-1.5410472155</y>
+ </vector>
+ </entry>
+ <entry>
+ <vector>
+ <x>1.8586863279</x>
+ <y>-1.5304071903</y>
+ </vector>
+ </entry>
+ <entry>
+ <vector>
+ <x>1.8513576984</x>
+ <y>0.3191995919</y>
+ </vector>
+ </entry>
+ <entry>
+ <vector>
+ <x>1.0852786303</x>
+ <y>-0.4468794465</y>
+ </vector>
+ </entry>
+ </dynamic_list>
+ </param>
+ </layer>
+ <layer type="polygon" active="true" version="0.1" desc="Blue Arrow">
+ <param name="z_depth">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="amount">
+ <real value="1.0000000000"/>
+ </param>
+ <param name="blend_method">
+ <integer value="0"/>
+ </param>
+ <param name="color">
+ <color>
+ <r>1.000000</r>
+ <g>1.000000</g>
+ <b>1.000000</b>
+ <a>1.000000</a>
+ </color>
+ </param>
+ <param name="offset">
+ <vector>
+ <x>0.0000000000</x>
+ <y>0.0000000000</y>
+ </vector>
+ </param>
+ <param name="invert">
+ <bool value="false"/>
+ </param>
+ <param name="antialias">
+ <bool value="true"/>
+ </param>
+ <param name="feather">
+ <real value="0.0000000000"/>
+ </param>
+ <param name="blurtype">
+ <integer value="1"/>
+ </param>
+ <param name="vector_list">
+ <dynamic_list type="vector">
+ <entry>
+ <vector>
+ <x>-1.7236778736</x>
+ <y>1.7875177860</y>
+ </vector>
+ </entry>
+ <entry>
+ <vector>
+ <x>-1.8407176733</x>
+ <y>1.6704779863</y>
+ </vector>
+ </entry>
+ <entry>
+ <vector>
+ <x>0.9682388306</x>
+ <y>-0.7979990244</y>
+ </vector>
+ </entry>
+ <entry>
+ <vector>
+ <x>0.4222880602</x>
+ <y>-1.3601673841</y>
+ </vector>
+ </entry>
+ <entry>
+ <vector>
+ <x>1.6990864277</x>
+ <y>-1.3601673841</y>
+ </vector>
+ </entry>
+ <entry>
+ <vector>
+ <x>1.6704779863</x>
+ <y>-0.1063998714</y>
+ </vector>
+ </entry>
+ <entry>
+ <vector>
+ <x>1.1065586805</x>
+ <y>-0.6703191996</y>
+ </vector>
+ </entry>
+ </dynamic_list>
+ </param>
+ </layer>
+</canvas>
src/gtkmm/state_polygon.h
src/gtkmm/state_rectangle.cpp
src/gtkmm/state_rectangle.h
-src/gtkmm/state_rotate.cpp
-src/gtkmm/state_rotate.h
-src/gtkmm/state_scale.cpp
-src/gtkmm/state_scale.h
src/gtkmm/state_sketch.cpp
src/gtkmm/state_sketch.h
src/gtkmm/state_smoothmove.cpp
+#
msgid ""
msgstr ""
"Project-Id-Version: Synfig Studio\n"
"Report-Msgid-Bugs-To: http://synfig.org/Bugs\n"
"POT-Creation-Date: 2009-10-07 04:46+0400\n"
-"PO-Revision-Date: 2009-10-09 21:06+0400\n"
+"PO-Revision-Date: 2009-12-24 19:21+0500\n"
"Last-Translator: Alexandre Prokoudine <alexandre.prokoudine@gmail.com>\n"
"Language-Team: Russian <gnome-cyr@lists.gnome.org>\n"
"MIME-Version: 1.0\n"
#: ../synfigstudio.desktop.in.h:1
msgid "Create and edit 2D animations and compositions"
-msgstr "Создание двухмерной векторной анимации"
+msgstr "Создание 2D векторной анимации и графики"
#: ../synfigstudio.desktop.in.h:2 ../src/gtkmm/app.cpp:1188
#: ../src/gtkmm/toolbox.cpp:360
#. TRANSLATORS: change this to your name, separate multiple names with \n
#: ../src/gtkmm/about.cpp:177
msgid "translator-credits"
-msgstr "Александр Прокудин <alexandre.prokoudine@gmail.com>"
+msgstr "Александр Прокудин <alexandre.prokoudine@gmail.com>\nКонстантин Дмитриев <ksee.zelgadis@gmail.com>"
#: ../src/gtkmm/about.cpp:204
#, c-format
"%s\n"
msgstr ""
"\n"
-"Ð\9dеÑ\81Ñ\82абилÑ\8cнаÑ\8f веÑ\80Ñ\81иÑ\8f:\n"
+"СбоÑ\80ка:\n"
"%s\n"
#: ../src/gtkmm/about.cpp:209
#: ../src/gtkmm/about.cpp:224
msgid "Using:\n"
-msgstr "Использование:\n"
+msgstr "Используется:\n"
#: ../src/gtkmm/about.cpp:225
#, c-format
#: ../src/gtkmm/app.cpp:738
msgid "Show/Hide Ducks"
-msgstr "Ð\9fоказаÑ\82Ñ\8c/Ñ\81кÑ\80Ñ\8bÑ\82Ñ\8c Ñ\80Ñ\83чки"
+msgstr "Ð\9fоказаÑ\82Ñ\8c/Ñ\81кÑ\80Ñ\8bÑ\82Ñ\8c Ñ\83Точки"
#: ../src/gtkmm/app.cpp:739
msgid "Preview Quality"
#: ../src/gtkmm/app.cpp:774 ../src/gtkmm/canvasview.cpp:1461
msgid "Render"
-msgstr "Ð\9eÑ\82Ñ\80иÑ\81овка"
+msgstr "Ð\92изÑ\83ализаÑ\86иÑ\8f"
#: ../src/gtkmm/app.cpp:775 ../src/gtkmm/canvasview.cpp:1464
#: ../src/gtkmm/dialog_preview.cpp:171
#: ../src/gtkmm/app.cpp:789 ../src/gtkmm/canvasview.cpp:1491
msgid "Select All Ducks"
-msgstr "Ð\92Ñ\8bбÑ\80аÑ\82Ñ\8c вÑ\81е Ñ\80Ñ\83чки"
+msgstr "Ð\92Ñ\8bделиÑ\82Ñ\8c вÑ\81е Ñ\83Точки"
#: ../src/gtkmm/app.cpp:790 ../src/gtkmm/canvasview.cpp:1495
msgid "Unselect All Ducks"
-msgstr "Снять выделение с ручек"
+msgstr "Снять выделение со всех уТочек"
#: ../src/gtkmm/app.cpp:791 ../src/gtkmm/canvasview.cpp:1499
msgid "Select All Layers"
#: ../src/gtkmm/app.cpp:795 ../src/gtkmm/canvasview.cpp:1669
msgid "Show Position Ducks"
-msgstr "Ð\9fоказÑ\8bваÑ\82Ñ\8c Ñ\80Ñ\83чки положения"
+msgstr "Ð\9fоказÑ\8bваÑ\82Ñ\8c Ñ\83Точки положения"
#: ../src/gtkmm/app.cpp:796 ../src/gtkmm/canvasview.cpp:1671
msgid "Show Vertex Ducks"
-msgstr "Ð\9fоказÑ\8bваÑ\82Ñ\8c Ñ\80Ñ\83чки вершин"
+msgstr "Ð\9fоказÑ\8bваÑ\82Ñ\8c Ñ\83Точки вершин"
#: ../src/gtkmm/app.cpp:797 ../src/gtkmm/canvasview.cpp:1670
msgid "Show Tangent Ducks"
-msgstr "Ð\9fоказÑ\8bваÑ\82Ñ\8c Ñ\80Ñ\83чки касательных"
+msgstr "Ð\9fоказÑ\8bваÑ\82Ñ\8c Ñ\83Точки касательных"
#: ../src/gtkmm/app.cpp:798 ../src/gtkmm/canvasview.cpp:1672
msgid "Show Radius Ducks"
-msgstr "Ð\9fоказÑ\8bваÑ\82Ñ\8c Ñ\80Ñ\83чки радиусов"
+msgstr "Ð\9fоказÑ\8bваÑ\82Ñ\8c Ñ\83Точки радиусов"
#: ../src/gtkmm/app.cpp:799 ../src/gtkmm/canvasview.cpp:1673
msgid "Show Width Ducks"
-msgstr "Ð\9fоказÑ\8bваÑ\82Ñ\8c Ñ\80Ñ\83чки толщины"
+msgstr "Ð\9fоказÑ\8bваÑ\82Ñ\8c Ñ\83Точки толщины"
#: ../src/gtkmm/app.cpp:800 ../src/gtkmm/canvasview.cpp:1674
msgid "Show Angle Ducks"
-msgstr "Ð\9fоказÑ\8bваÑ\82Ñ\8c Ñ\80Ñ\83чки углов"
+msgstr "Ð\9fоказÑ\8bваÑ\82Ñ\8c Ñ\83Точки углов"
#: ../src/gtkmm/app.cpp:801 ../src/gtkmm/canvasview.cpp:1522
msgid "Use Parametric Renderer"
"\n"
"http://www.synfig.org/Documentation"
msgstr ""
-"Ð\94окÑ\83менÑ\82аÑ\86иÑ\8f по Synfig Studio доÑ\81Ñ\82Ñ\83пна на Ñ\81айÑ\82е:\n"
+"Ð\94окÑ\83менÑ\82аÑ\86иÑ\8f по Synfig Studio доÑ\81Ñ\82Ñ\83пна по адÑ\80еÑ\81Ñ\83:\n"
"\n"
"http://www.synfig.org/Documentation"
#: ../src/gtkmm/canvasview.cpp:2059 ../src/gtkmm/canvasview.cpp:2532
msgid "Select All Children"
-msgstr "Выделить всех потомков"
+msgstr "Выделить содержимое"
#: ../src/gtkmm/canvasview.cpp:2345
msgid "-MODIFIED"
#: ../src/gtkmm/canvasview.cpp:2798 ../src/gtkmm/iconcontroller.cpp:185
#: ../src/gtkmm/keyframedial.cpp:59
msgid "All Keyframes Locked"
-msgstr "Ð\92Ñ\81е клÑ\8eÑ\87евÑ\8bе кадÑ\80Ñ\8b запеÑ\80Ñ\82ы"
+msgstr "Ð\92Ñ\81е клÑ\8eÑ\87евÑ\8bе кадÑ\80Ñ\8b заблокиÑ\80ованы"
#: ../src/gtkmm/canvasview.cpp:2808 ../src/gtkmm/iconcontroller.cpp:187
msgid "Future Keyframes Locked"
#: ../src/gtkmm/canvasview.cpp:2828 ../src/gtkmm/iconcontroller.cpp:188
msgid "No Keyframes Locked"
-msgstr "Ð\9dеÑ\82 запеÑ\80Ñ\82ых ключевых кадров"
+msgstr "Ð\9dеÑ\82 заблокиÑ\80ованных ключевых кадров"
#: ../src/gtkmm/canvasview.cpp:3587
msgid "Change Waypoint Group"
#: ../src/gtkmm/dialog_preview.cpp:129 ../src/gtkmm/renddesc.cpp:546
msgid "_Frames per second"
-msgstr "_Кадров/с:"
+msgstr "_Кадров в секунду:"
#: ../src/gtkmm/dialog_preview.cpp:138 ../src/gtkmm/renddesc.cpp:532
msgid "Time Settings"
-msgstr "Ð\92Ñ\80еменнÑ\8bе паÑ\80амеÑ\82Ñ\80Ñ\8b"
+msgstr "Ð\9fаÑ\80амеÑ\82Ñ\80Ñ\8b вÑ\80емени"
#: ../src/gtkmm/dialog_preview.cpp:140 ../src/gtkmm/renddesc.cpp:534
msgid "<b>Time Settings</b>"
-msgstr "<b>Ð\92Ñ\80еменнÑ\8bе паÑ\80амеÑ\82Ñ\80Ñ\8b</b>"
+msgstr "<b>Ð\9fаÑ\80амеÑ\82Ñ\80Ñ\8b вÑ\80емени</b>"
#: ../src/gtkmm/dialog_setup.cpp:73
msgid "Synfig Studio Setup"
#: ../src/gtkmm/dialog_setup.cpp:81
msgid "Use Only a Single Thread"
-msgstr "Ð\98Ñ\81полÑ\8cзоваÑ\82Ñ\8c Ñ\82олÑ\8cко однÑ\83 ниÑ\82Ñ\8c"
+msgstr "Ð\98Ñ\81полÑ\8cзоваÑ\82Ñ\8c Ñ\82олÑ\8cко один поÑ\82ок"
#: ../src/gtkmm/dialog_setup.cpp:83
msgid "Restrict Real-Valued Ducks to Top Right Quadrant"
-msgstr "Ð\9eгÑ\80аниÑ\87иÑ\82Ñ\8c веÑ\80Ñ\85ним пÑ\80авÑ\8bм квадÑ\80анÑ\82ом Ñ\80Ñ\83Ñ\87ки Ñ\81 Ñ\80еалÑ\8cнÑ\8bм значением"
+msgstr "Ð\9eгÑ\80аниÑ\87иÑ\82Ñ\8c веÑ\80Ñ\85ним пÑ\80авÑ\8bм квадÑ\80анÑ\82ом Ñ\83ТоÑ\87ки, задаÑ\8eÑ\89ие Ñ\87иÑ\81ловое значением"
#: ../src/gtkmm/dialog_setup.cpp:84
msgid "Scale New Imported Images to Fit Canvas"
#: ../src/gtkmm/dialog_setup.cpp:181
msgid "Points"
-msgstr "Ð\9fÑ\83нкÑ\82"
+msgstr "ТоÑ\87ка"
#: ../src/gtkmm/dialog_setup.cpp:182
msgid "Inches"
#: ../src/gtkmm/dialog_setup.cpp:289
msgid "New Document FPS"
-msgstr "Ð\9fо Ñ\83молÑ\87аниÑ\8e"
+msgstr "ЧаÑ\81Ñ\82оÑ\82а кадÑ\80ов"
#: ../src/gtkmm/dialog_setup.cpp:291
msgid "Frames per second of the new created document"
#: ../src/gtkmm/dialog_setup.h:51
msgid "Custom Size"
-msgstr "Ð\97аказной размер"
+msgstr "Ð\94Ñ\80Ñ\83гой размер"
#: ../src/gtkmm/dialog_setup.h:54
msgid "Custom fps"
-msgstr "Ð\97аказное колиÑ\87еÑ\81Ñ\82во"
+msgstr "Ð\94Ñ\80Ñ\83гоаÑ\8f Ñ\87аÑ\81Ñ\82оÑ\82а кадÑ\80ов"
#: ../src/gtkmm/dialog_soundselect.cpp:60
msgid "Sound Select"
#: ../src/gtkmm/dialog_soundselect.cpp:68
msgid "<b>Sound Parameters</b>"
-msgstr "<b>Параметры</b>"
+msgstr "<b>Параметры звука</b>"
#: ../src/gtkmm/dialog_soundselect.cpp:76
msgid "_Sound File"
#: ../src/gtkmm/dialog_soundselect.cpp:79
msgid "Time _Offset"
-msgstr "_Смещение во времени"
+msgstr "_Смещение времени"
#: ../src/gtkmm/dialog_tooloptions.cpp:56
#: ../src/gtkmm/dialog_tooloptions.cpp:78
#: ../src/gtkmm/dock_history.cpp:216 ../src/gtkmm/keyframetree.cpp:96
msgid "(JMP)"
-msgstr "(Ð\9fÐ¥Ð\94)"
+msgstr "(пеÑ\80ейÑ\82и)"
#: ../src/gtkmm/dock_history.cpp:228
msgid "Action"
msgid ""
"You will not be able to undo any changes that you have made!\n"
"Are you sure you want to clear the undo stack?"
-msgstr "Вы не сможете "
+msgstr "Вы не сможете отменить сделанные ранее изменения!\n"
+"Уверены, что хотите очистить историю действий?"
#: ../src/gtkmm/dock_history.cpp:284
msgid ""
#: ../src/gtkmm/iconcontroller.cpp:173 ../src/gtkmm/layeractionmanager.cpp:135
msgid "Select All Child Layers"
-msgstr "Выбрать все слои-потомки"
+msgstr "Выбрать все вложенные слои"
#: ../src/gtkmm/iconcontroller.cpp:181
msgid "MetaData"
#: ../src/gtkmm/iconcontroller.cpp:198 ../src/gtkmm/toggleducksdial.cpp:55
msgid "Toggle position ducks"
-msgstr "Ð\9fеÑ\80еклÑ\8eÑ\87иÑ\82Ñ\8c Ñ\80Ñ\83чки положения"
+msgstr "Ð\9fеÑ\80еклÑ\8eÑ\87иÑ\82Ñ\8c Ñ\83Точки положения"
#: ../src/gtkmm/iconcontroller.cpp:199 ../src/gtkmm/toggleducksdial.cpp:56
msgid "Toggle vertex ducks"
-msgstr "Ð\9fеÑ\80еклÑ\8eÑ\87иÑ\82Ñ\8c Ñ\80Ñ\83чки вершин"
+msgstr "Ð\9fеÑ\80еклÑ\8eÑ\87иÑ\82Ñ\8c Ñ\83Точки вершин"
#: ../src/gtkmm/iconcontroller.cpp:200 ../src/gtkmm/toggleducksdial.cpp:57
msgid "Toggle tangent ducks"
-msgstr "Ð\9fеÑ\80еклÑ\8eÑ\87иÑ\82Ñ\8c Ñ\80Ñ\83чки касательных"
+msgstr "Ð\9fеÑ\80еклÑ\8eÑ\87иÑ\82Ñ\8c Ñ\83Точки касательных"
#: ../src/gtkmm/iconcontroller.cpp:201 ../src/gtkmm/toggleducksdial.cpp:58
msgid "Toggle radius ducks"
-msgstr "Ð\9fеÑ\80еклÑ\8eÑ\87иÑ\82Ñ\8c Ñ\80Ñ\83чки радиусов"
+msgstr "Ð\9fеÑ\80еклÑ\8eÑ\87иÑ\82Ñ\8c Ñ\83Точки радиусов"
#: ../src/gtkmm/iconcontroller.cpp:202 ../src/gtkmm/toggleducksdial.cpp:59
msgid "Toggle width ducks"
-msgstr "Ð\9fеÑ\80еклÑ\8eÑ\87иÑ\82Ñ\8c Ñ\80Ñ\83чки ширины"
+msgstr "Ð\9fеÑ\80еклÑ\8eÑ\87иÑ\82Ñ\8c Ñ\83Точки ширины"
#: ../src/gtkmm/iconcontroller.cpp:203 ../src/gtkmm/toggleducksdial.cpp:60
msgid "Toggle angle ducks"
-msgstr "Ð\9fеÑ\80еклÑ\8eÑ\87иÑ\82Ñ\8c Ñ\80Ñ\83чки углов"
+msgstr "Ð\9fеÑ\80еклÑ\8eÑ\87иÑ\82Ñ\8c Ñ\83Точки углов"
#: ../src/gtkmm/iconcontroller.cpp:205
msgid "Toggle show grid"
#: ../src/gtkmm/iconcontroller.cpp:214
msgid "Render Options Dialog"
-msgstr "Ð\9fаÑ\80амеÑ\82Ñ\80Ñ\8b оÑ\82Ñ\80иÑ\81овки"
+msgstr "Ð\9fаÑ\80амеÑ\82Ñ\80Ñ\8b визÑ\83ализаÑ\86ии"
#: ../src/gtkmm/iconcontroller.cpp:216
msgid "CVS Add"
#: ../src/gtkmm/iconcontroller.cpp:228 ../src/gtkmm/state_sketch.cpp:325
#: ../src/gtkmm/state_sketch.cpp:399
msgid "Sketch Tool"
-msgstr "РаÑ\81Ñ\82Ñ\80овÑ\8bй каÑ\80андаÑ\88"
+msgstr "ÐÑ\81киз"
#: ../src/gtkmm/iconcontroller.cpp:229 ../src/gtkmm/state_circle.cpp:432
#: ../src/gtkmm/state_circle.cpp:496
msgid "Circle Tool"
-msgstr "Ð\9aÑ\80Ñ\83ги и Ñ\8dллипÑ\81Ñ\8b"
+msgstr "Ð\9eкÑ\80Ñ\83жноÑ\81Ñ\82и"
#: ../src/gtkmm/iconcontroller.cpp:230 ../src/gtkmm/state_rectangle.cpp:352
#: ../src/gtkmm/state_rectangle.cpp:408
#: ../src/gtkmm/iconcontroller.cpp:231 ../src/gtkmm/state_smoothmove.cpp:177
msgid "SmoothMove Tool"
-msgstr "Ð\9fеÑ\80емеÑ\89ение"
+msgstr "Ð\94еÑ\84оÑ\80маÑ\86иÑ\8f"
#: ../src/gtkmm/iconcontroller.cpp:232 ../src/gtkmm/state_scale.cpp:167
#: ../src/gtkmm/state_scale.cpp:193
#: ../src/gtkmm/layeractionmanager.cpp:129
msgid "Amount"
-msgstr "ЧиÑ\81ло"
+msgstr "Ð\92елиÑ\87ина"
#: ../src/gtkmm/layeractionmanager.cpp:365
msgid "Paste"
#: ../src/gtkmm/preview.cpp:382
msgid "Re-Preview"
-msgstr "Ð\9eÑ\82кÑ\80Ñ\8bÑ\82Ñ\8c диалог паÑ\80амеÑ\82Ñ\80ов"
+msgstr "Ð\9fеÑ\80еÑ\81Ñ\87иÑ\82аÑ\82Ñ\8c"
#: ../src/gtkmm/preview.cpp:388
msgid "Erase All"
#: ../src/gtkmm/renddesc.cpp:574
msgid "Locks and Links"
-msgstr "Ð\97апиÑ\80ание и связи"
+msgstr "Ð\91локиÑ\80овки и связи"
#: ../src/gtkmm/renddesc.cpp:576
msgid "<b>Locks and Links</b>"
-msgstr "<b>Ð\97апиÑ\80ание и связи</b>"
+msgstr "<b>Ð\91локиÑ\80овки и связи</b>"
#: ../src/gtkmm/renddesc.cpp:597
msgid "Focus Point"
#: ../src/gtkmm/render.cpp:63 ../src/gtkmm/render.cpp:179
msgid "Render Settings"
-msgstr "Ð\9fаÑ\80амеÑ\82Ñ\80Ñ\8b оÑ\82Ñ\80иÑ\81овки"
+msgstr "Ð\9fаÑ\80амеÑ\82Ñ\80Ñ\8b визÑ\83ализаÑ\86ии"
#: ../src/gtkmm/render.cpp:69
msgid "Use _current frame"
#: ../src/gtkmm/render.cpp:318
msgid "Rendering "
-msgstr "Ð\9eÑ\82Ñ\80иÑ\81овка"
+msgstr "Ð\92изÑ\83ализаÑ\86иÑ\8f"
#: ../src/gtkmm/render.cpp:346
msgid "File rendered successfully"
#: ../src/gtkmm/resolutiondial.cpp:57
msgid "Decrease Display Resolution"
-msgstr "УменÑ\8cÑ\88иÑ\82Ñ\8c Ñ\80азÑ\80еÑ\88ение длÑ\8f пÑ\80оÑ\81моÑ\82Ñ\80а"
+msgstr "Уменьшить разрешение просмотра"
#: ../src/gtkmm/resolutiondial.cpp:58
msgid "Low Res"
#: ../src/gtkmm/state_draw.cpp:414 ../src/gtkmm/state_polygon.cpp:326
#: ../src/gtkmm/state_rectangle.cpp:343 ../src/gtkmm/state_star.cpp:443
msgid "Create Outline BLine"
-msgstr "СоздаÑ\82Ñ\8c кÑ\80ивÑ\83Ñ\8e абÑ\80иÑ\81а"
+msgstr "СоздаÑ\82Ñ\8c кÑ\80ивÑ\83Ñ\8e конÑ\82Ñ\83Ñ\80а"
#: ../src/gtkmm/state_bline.cpp:363 ../src/gtkmm/state_circle.cpp:406
#: ../src/gtkmm/state_polygon.cpp:327 ../src/gtkmm/state_rectangle.cpp:344
#: ../src/gtkmm/state_star.cpp:444
msgid "Create Curve Gradient BLine"
-msgstr "Создать градиентную кривую"
+msgstr "Создать градиент по кривой"
#: ../src/gtkmm/state_bline.cpp:364 ../src/gtkmm/state_circle.cpp:407
#: ../src/gtkmm/state_polygon.cpp:328 ../src/gtkmm/state_rectangle.cpp:345
#: ../src/gtkmm/state_star.cpp:445
msgid "Create Plant BLine"
-msgstr "СоздаÑ\82Ñ\8c кÑ\80ивÑ\83Ñ\8e Ñ\80аÑ\81Ñ\82ениÑ\8f"
+msgstr "СоздаÑ\82Ñ\8c кÑ\80ивÑ\83Ñ\8e Ñ\81 Ñ\80аÑ\81Ñ\82ениÑ\8fми"
#: ../src/gtkmm/state_bline.cpp:365 ../src/gtkmm/state_circle.cpp:408
#: ../src/gtkmm/state_polygon.cpp:329 ../src/gtkmm/state_star.cpp:446
#: ../src/gtkmm/state_bline.cpp:1378
#: ../src/synfigapp/actions/blinepointtangentmerge.cpp:56
msgid "Merge Tangents"
-msgstr "Ð\9eбÑ\8aединить касательные"
+msgstr "СвÑ\8fзать касательные"
#: ../src/gtkmm/state_bline.cpp:1385
#: ../src/synfigapp/actions/blinepointtangentsplit.cpp:56
#: ../src/gtkmm/state_draw.cpp:410
msgid "Auto Loop"
-msgstr "Ð\90вÑ\82оÑ\86икл"
+msgstr "Ð\97амÑ\8bкаÑ\82Ñ\8c авÑ\82омаÑ\82иÑ\87еÑ\81ки"
#: ../src/gtkmm/state_draw.cpp:411
msgid "Auto Extend"
#: ../src/gtkmm/state_gradient.cpp:271
msgid "Gradient Type"
-msgstr "Тип градиент"
+msgstr "Тип градиента"
#: ../src/gtkmm/state_gradient.cpp:272
msgid "Determines the type of Gradient used"
#: ../src/gtkmm/state_sketch.cpp:241
msgid "Show Sketch"
-msgstr "Ð\9fоказÑ\8bвать эскиз"
+msgstr "Ð\9eÑ\82обÑ\80ажать эскиз"
#: ../src/gtkmm/state_sketch.cpp:256 ../src/gtkmm/state_sketch.cpp:257
msgid "Undo Last Stroke"
#: ../src/gtkmm/state_sketch.cpp:280 ../src/gtkmm/state_sketch.cpp:281
#: ../src/gtkmm/state_sketch.cpp:292 ../src/gtkmm/state_sketch.cpp:293
msgid "Save Sketch As..."
-msgstr "Ð\9eÑ\87иÑ\81Ñ\82ить эскиз как..."
+msgstr "СоÑ\85Ñ\80анить эскиз как..."
#: ../src/gtkmm/state_sketch.cpp:304 ../src/gtkmm/state_sketch.cpp:305
msgid "Open a Sketch"
#. TRANSLATORS: Help menu entry
#: ../src/gtkmm/toolbox.cpp:273
msgid "Keyboard Shortcuts"
-msgstr "Ð\9aлавиаÑ\82Ñ\83Ñ\80нÑ\8bе комбинаÑ\86ии"
+msgstr "Ð\9aомбинаÑ\86ии клавиÑ\88"
#. TRANSLATORS: a wiki page
#: ../src/gtkmm/toolbox.cpp:273
#: ../src/gtkmm/toolbox.cpp:290
msgid "New..."
-msgstr "Создать"
+msgstr "Создать..."
#: ../src/gtkmm/toolbox.cpp:291
msgid "Open..."
#: ../src/gtkmm/widget_canvaschooser.cpp:115
msgid "Other..."
-msgstr "Ð\94Ñ\80Ñ\83гое..."
+msgstr "Ð\94Ñ\80Ñ\83гой..."
#: ../src/gtkmm/widget_canvaschooser.cpp:136
msgid "Choose Canvas"
#: ../src/gtkmm/widget_coloredit.cpp:382
msgid "Alpha"
-msgstr "Ð\90лÑ\8cÑ\84а"
+msgstr "Ð\9fÑ\80озÑ\80аÑ\87ноÑ\81Ñ\82Ñ\8c"
#: ../src/gtkmm/widget_defaults.cpp:215
msgid "Outline Color"
-msgstr "ЦвеÑ\82 обводки"
+msgstr "ЦвеÑ\82 конÑ\82Ñ\83Ñ\80а"
#: ../src/gtkmm/widget_defaults.cpp:223
msgid "Fill Color"
#: ../src/gtkmm/widget_waypoint.cpp:175
msgid "TCB Parameters"
-msgstr "Параметры TCB"
+msgstr "TCB-параметры"
#: ../src/gtkmm/widget_waypoint.cpp:177
msgid "<b>TCB Parameter</b>"
-msgstr "<b>Параметр TCB</b>"
+msgstr "<b>TCB-параметр</b>"
#: ../src/gtkmm/widget_waypoint.cpp:189
msgid "T_ension"
#: ../src/gtkmm/workarea.cpp:2339
msgid "Rendering..."
-msgstr "Ð\9eÑ\82Ñ\80иÑ\81овка..."
+msgstr "Ð\92изÑ\83ализаÑ\86иÑ\8f..."
#: ../src/gtkmm/workarea.cpp:2366 ../src/gtkmm/workarea.cpp:2458
msgid "Render Failed"
-msgstr "Ð\9dе Ñ\83далоÑ\81Ñ\8c оÑ\82Ñ\80иÑ\81овать"
+msgstr "Ð\9dе Ñ\83далоÑ\81Ñ\8c визÑ\83ализиÑ\80овать"
#: ../src/gtkmm/workarea.cpp:2440
#, c-format
msgid "Rendering canvas %s..."
-msgstr "Ð\9eÑ\82Ñ\80иÑ\81овка холста %s..."
+msgstr "Ð\92изÑ\83ализаÑ\86иÑ\8f холста %s..."
#: ../src/gtkmm/zoomdial.cpp:55
msgid "Zoom In"
#: ../src/synfigapp/actions/valuedescset.cpp:542
msgid "You must be in Animate-Editing-Mode to directly manipulate this value"
-msgstr ""
-"Для прямого редактирования этого значения необходимо быть в режиме анимации"
+msgstr "Для прямого редактирования этого значения необходимо быть в режиме анимации"
#: ../src/synfigapp/actions/valuedescset.cpp:564
msgid "Unsupported ValueDesc type"
#: ../src/synfigapp/actions/valuenodedynamiclistrotateorder.cpp:50
msgid "Rotate Order"
-msgstr "Ð\9fоÑ\80Ñ\8fдок вÑ\80аÑ\89ениÑ\8f"
+msgstr "СмениÑ\82Ñ\8c поÑ\80Ñ\8fдок"
#: ../src/synfigapp/actions/valuenodedynamiclistunloop.cpp:50
msgid "Unloop"
-msgstr "СнÑ\8fÑ\82Ñ\8c пеÑ\82лÑ\8e"
+msgstr "РазомкнÑ\83Ñ\82Ñ\8c"
#: ../src/synfigapp/actions/valuenodelinkconnect.cpp:49
msgid "Connect ValueNode Link"
#: ../src/synfigapp/action_system.cpp:148
#: ../src/synfigapp/action_system.cpp:159
msgid "Failed"
-msgstr ". Неуспешно."
+msgstr "Неуспешно."
#: ../src/synfigapp/action_system.cpp:192
msgid "Successful"
#: ../src/synfigapp/canvasinterface.cpp:641
msgid "I don't know how to open images of this type -- "
-msgstr "Ð\9fÑ\80огÑ\80амма не Ñ\83мееÑ\82 оÑ\82кÑ\80Ñ\8bваÑ\82Ñ\8c Ñ\84айлÑ\8b Ñ\81 Ñ\80аÑ\81Ñ\88иÑ\80ением "
+msgstr "Ð\9fÑ\80огÑ\80амма не Ñ\83мееÑ\82 оÑ\82кÑ\80Ñ\8bваÑ\82Ñ\8c Ñ\84айлÑ\8b Ñ\84оÑ\80маÑ\82а "
#: ../src/synfigapp/canvasinterface.cpp:808
#, c-format
state_fill.h \
state_gradient.h \
state_normal.h \
- state_null.h \
state_polygon.h \
state_rectangle.h \
+ state_rotate.h \
+ state_scale.h \
state_sketch.h \
state_smoothmove.h \
state_star.h \
state_fill.cpp \
state_gradient.cpp \
state_normal.cpp \
- state_null.cpp \
state_polygon.cpp \
state_rectangle.cpp \
+ state_rotate.cpp \
+ state_scale.cpp \
state_sketch.cpp \
state_smoothmove.cpp \
state_star.cpp \
#include "state_circle.h"
#include "state_rectangle.h"
#include "state_smoothmove.h"
+#include "state_scale.h"
#include "state_star.h"
#include "state_text.h"
#include "state_width.h"
+#include "state_rotate.h"
#include "state_zoom.h"
#include "devicetracker.h"
/* editing tools */
state_manager->add_state(&state_normal);
state_manager->add_state(&state_smooth_move);
+ state_manager->add_state(&state_scale);
+ state_manager->add_state(&state_rotate);
studio_init_cb.task(_("Init ModMirror...")); module_list_.push_back(new ModMirror()); module_list_.back()->start();
if(!getenv("SYNFIG_DISABLE_WIDTH" )) state_manager->add_state(&state_width); // Enabled since 0.61.09
/* new objects */
- state_manager->add_state(&state_bline);
state_manager->add_state(&state_circle);
state_manager->add_state(&state_rectangle);
state_manager->add_state(&state_star);
state_manager->add_state(&state_gradient);
if(!getenv("SYNFIG_DISABLE_POLYGON")) state_manager->add_state(&state_polygon); // Enabled - for working without ducks
state_manager->add_state(&state_text);
+ state_manager->add_state(&state_bline);
if(!getenv("SYNFIG_DISABLE_DRAW" )) state_manager->add_state(&state_draw); // Enabled for now. Let's see whether they're good enough yet.
/* other */
-
state_manager->add_state(&state_fill);
state_manager->add_state(&state_eyedrop);
state_manager->add_state(&state_zoom);
{
file_type_enum = manage(new Widget_Enum());
file_type_enum->set_param_desc(ParamDesc().set_hint("enum")
- .add_enum_value(synfig::RELEASE_VERSION_0_61_09, "0.61.09", strprintf("0.61.09 (%s)", _("current")))
+ .add_enum_value(synfig::RELEASE_VERSION_0_62_00, "0.62.00", strprintf("0.62.00 (%s)", _("current")))
+ .add_enum_value(synfig::RELEASE_VERSION_0_61_09, "0.61.09", "0.61.09")
.add_enum_value(synfig::RELEASE_VERSION_0_61_08, "0.61.08", "0.61.08")
.add_enum_value(synfig::RELEASE_VERSION_0_61_07, "0.61.07", "0.61.07")
.add_enum_value(synfig::RELEASE_VERSION_0_61_06, "0.61.06", strprintf("0.61.06 %s", _("and older"))));
#include "dialog_color.h"
#include "eventkey.h"
-#include "state_null.h"
#include "state_polygon.h"
#include "state_bline.h"
#include "state_normal.h"
toggling_snap_grid=false;
toggling_onion_skin=false;
- smach_.set_default_state(&state_null);
-
disp_audio = new Widget_Sound();
//synfig::info("Canvasview: Entered constructor");
//set_transient_for(*App::toolbox);
+ smach_.set_default_state(&state_normal);
+
//synfig::info("Canvasview: Before Signals");
/*
-- ** -- Signals -------------------------------------------------------------
#ifdef SINGLE_THREADED
// Misc - single_threaded
- misc_table->attach(toggle_single_threaded, 0, 2, 9, 10, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, xpadding, ypadding);
+ misc_table->attach(toggle_single_threaded, 0, 2, 10, 11, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, xpadding, ypadding);
#endif
// Misc - auto backup interval
/* === M E T H O D S ======================================================= */
Dialog_ToolOptions::Dialog_ToolOptions():
- Dockable("tool_options",_("Tool Options"),Gtk::StockID("synfig-null")),
+ Dockable("tool_options",_("Tool Options"),Gtk::StockID("synfig-about")),
empty_label(_("This tool has no options"))
{
//scrolled_.add(sub_vbox_);
set_widget(empty_label);
empty_label.show();
- set_stock_id(Gtk::StockID("synfig-null"));
+ set_stock_id(Gtk::StockID("synfig-about"));
}
void
INIT_STOCK_ICON_CLONE(cvs_revert,"gtk-revert",_("CVS Revert"));
// Tools
- INIT_STOCK_ICON(null,"null_icon."IMAGE_EXT,_("Null Tool"));
INIT_STOCK_ICON(normal,"normal_icon."IMAGE_EXT,_("Normal Tool"));
INIT_STOCK_ICON(transform,"transform_icon."IMAGE_EXT,_("Transform Tool"));
INIT_STOCK_ICON(polygon,"polyline_icon."IMAGE_EXT,_("Polygon Tool"));
INIT_STOCK_ICON(circle,"circle_icon."IMAGE_EXT,_("Circle Tool"));
INIT_STOCK_ICON(rectangle,"rectangle_icon."IMAGE_EXT,_("Rectangle Tool"));
INIT_STOCK_ICON(smooth_move,"smooth_move_icon."IMAGE_EXT,_("SmoothMove Tool"));
+ INIT_STOCK_ICON(rotate,"rotate_icon."IMAGE_EXT,"Rotate Tool");
INIT_STOCK_ICON(width,"width_icon."IMAGE_EXT,_("Width Tool"));
+ INIT_STOCK_ICON(scale,"scale_icon."IMAGE_EXT,"Scale Tool");
INIT_STOCK_ICON(zoom,"zoom_icon."IMAGE_EXT,_("Zoom Tool"));
INIT_STOCK_ICON(info,"info_icon."IMAGE_EXT,_("Info Tool"));
INIT_STOCK_ICON(mirror,"mirror_icon."IMAGE_EXT,_("Mirror Tool"));
#include <synfigapp/action_system.h>
#include "state_mirror.h"
+#include "../state_normal.h"
#include "../canvasview.h"
#include "../workarea.h"
#include "../app.h"
class studio::StateMirror_Context : public sigc::trackable
{
etl::handle<CanvasView> canvas_view_;
+ CanvasView::IsWorking is_working;
synfigapp::Settings& settings;
void update_axes()
{
duck_dragger_->axis=get_axis();
+ get_work_area()->set_cursor(get_axis() == AXIS_X?Gdk::SB_H_DOUBLE_ARROW:Gdk::SB_V_DOUBLE_ARROW);
}
+ Smach::event_result event_stop_handler(const Smach::event& x);
Smach::event_result event_refresh_tool_options(const Smach::event& x);
void refresh_tool_options();
Smach::state<StateMirror_Context>("mirror")
{
insert(event_def(EVENT_REFRESH_TOOL_OPTIONS,&StateMirror_Context::event_refresh_tool_options));
+ insert(event_def(EVENT_STOP,&StateMirror_Context::event_stop_handler));
}
StateMirror::~StateMirror()
StateMirror_Context::StateMirror_Context(CanvasView* canvas_view):
canvas_view_(canvas_view),
+ is_working(*canvas_view),
settings(synfigapp::Main::get_selected_input_device()->settings()),
duck_dragger_(new DuckDrag_Mirror()),
radiobutton_axis_x(radiobutton_group,_("Horizontal")),
keypress_connect=get_work_area()->signal_key_press_event().connect(sigc::mem_fun(*this,&StateMirror_Context::key_event),false);
keyrelease_connect=get_work_area()->signal_key_release_event().connect(sigc::mem_fun(*this,&StateMirror_Context::key_event),false);
-// get_canvas_view()->work_area->set_cursor(Gdk::CROSSHAIR);
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->set_cursor(Gdk::SB_H_DOUBLE_ARROW);
+// get_work_area()->reset_cursor();
App::toolbox->refresh();
StateMirror_Context::key_event(GdkEventKey *event)
{
if (event->keyval==GDK_Shift_L || event->keyval==GDK_Shift_R )
+ {
set_axis(get_axis()==AXIS_X ? AXIS_Y:AXIS_X);
+ get_work_area()->set_cursor(get_axis() == AXIS_X?Gdk::SB_H_DOUBLE_ARROW:Gdk::SB_V_DOUBLE_ARROW);
+ }
return false; //Pass on the event to other handlers, just in case
}
return Smach::RESULT_ACCEPT;
}
+Smach::event_result
+StateMirror_Context::event_stop_handler(const Smach::event& /*x*/)
+{
+ throw &state_normal;
+ return Smach::RESULT_OK;
+}
StateMirror_Context::~StateMirror_Context()
{
save_settings();
get_work_area()->clear_duck_dragger();
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
keypress_connect.disconnect();
keyrelease_connect.disconnect();
#include <synfig/valuenode_dynamiclist.h>
#include "state_bline.h"
+#include "state_normal.h"
#include "canvasview.h"
#include "workarea.h"
#include "app.h"
Smach::event_result event_layer_selection_changed_handler(const Smach::event& /*x*/)
{
if(egress_on_selection_change)
- throw Smach::egress_exception();
+ throw &state_normal; //throw Smach::egress_exception();
return Smach::RESULT_OK;
}
// Connect a signal
//get_work_area()->signal_user_click().connect(sigc::mem_fun(*this,&studio::StateBLine_Context::on_user_click));
- get_canvas_view()->work_area->set_cursor(Gdk::CROSSHAIR);
+ get_work_area()->set_cursor(Gdk::CROSSHAIR);
App::toolbox->refresh();
}
save_settings();
App::dialog_tool_options->clear();
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
// Restore layer clicking
get_work_area()->set_allow_layer_clicks(prev_workarea_layer_status_);
#include <synfig/valuenode_bline.h>
#include "state_circle.h"
+#include "state_normal.h"
#include "canvasview.h"
#include "workarea.h"
#include "app.h"
Smach::event_result event_layer_selection_changed_handler(const Smach::event& /*x*/)
{
if(egress_on_selection_change)
- throw Smach::egress_exception();
+ throw &state_normal; //throw Smach::egress_exception();
return Smach::RESULT_OK;
}
// Connect a signal
//get_work_area()->signal_user_click().connect(sigc::mem_fun(*this,&studio::StateCircle_Context::on_user_click));
- get_canvas_view()->work_area->set_cursor(Gdk::CROSSHAIR);
+ get_work_area()->set_cursor(Gdk::CROSSHAIR);
App::toolbox->refresh();
}
// Restore layer clicking
get_work_area()->set_allow_layer_clicks(prev_workarea_layer_status_);
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
App::dialog_tool_options->clear();
Smach::event_result
StateCircle_Context::event_stop_handler(const Smach::event& /*x*/)
{
- throw Smach::egress_exception();
+ //throw Smach::egress_exception();
+ throw &state_normal;
+ return Smach::RESULT_OK;
}
Smach::event_result
#include "state_draw.h"
#include "state_stroke.h"
+#include "state_normal.h"
#include "canvasview.h"
#include "workarea.h"
#include "app.h"
// Connect a signal
//get_work_area()->signal_user_click().connect(sigc::mem_fun(*this,&studio::StateDraw_Context::on_user_click));
- get_canvas_view()->work_area->set_cursor(Gdk::PENCIL);
+ get_work_area()->set_cursor(Gdk::PENCIL);
App::toolbox->refresh();
get_work_area()->set_type_mask(old_duckmask);
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
// Restore layer clicking
get_work_area()->set_allow_layer_clicks(prev_workarea_layer_status_);
Smach::event_result
StateDraw_Context::event_stop_handler(const Smach::event& /*x*/)
{
- throw Smach::egress_exception();
+ //throw Smach::egress_exception();
+ throw &state_normal;
+ return Smach::RESULT_OK;
}
Smach::event_result
#endif
#include "state_eyedrop.h"
+#include "state_normal.h"
#include "workarea.h"
#include <synfig/context.h>
#include "app.h"
Smach::event_result
StateEyedrop_Context::event_stop_handler(const Smach::event& /*x*/)
{
- synfig::info("STATE EYEDROP: Received Stop Event");
- throw Smach::egress_exception();
+ //synfig::info("STATE EYEDROP: Received Stop Event");
+ //throw Smach::egress_exception();
+ throw &state_normal;
+ return Smach::RESULT_OK;
// canvas_view->get_smach().pop_state();
// return Smach::RESULT_ACCEPT;
}
#endif
#include "state_fill.h"
+#include "state_normal.h"
#include "workarea.h"
#include <synfig/context.h>
#include "app.h"
StateFill_Context::event_stop_handler(const Smach::event& /*x*/)
{
synfig::info("STATE FILL: Received Stop Event");
- throw Smach::egress_exception();
+ //throw Smach::egress_exception();
+ throw &state_normal;
+ return Smach::RESULT_OK;
// canvas_view->get_smach().pop_state();
// return Smach::RESULT_ACCEPT;
}
#include <synfigapp/action_system.h>
#include "state_gradient.h"
+#include "state_normal.h"
#include "canvasview.h"
#include "workarea.h"
#include "app.h"
Smach::event_result event_layer_selection_changed_handler(const Smach::event& /*x*/)
{
if(egress_on_selection_change)
- throw Smach::egress_exception();
+ throw &state_normal; //throw Smach::egress_exception();
return Smach::RESULT_OK;
}
// Turn off layer clicking
get_work_area()->set_allow_layer_clicks(false);
- get_canvas_view()->work_area->set_cursor(Gdk::CROSSHAIR);
+ get_work_area()->set_cursor(Gdk::CROSSHAIR);
// clear out the ducks
get_work_area()->clear_ducks();
// Restore layer clicking
// get_work_area()->set_allow_layer_clicks(prev_workarea_layer_status_);
get_work_area()->set_allow_layer_clicks(true);
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
App::dialog_tool_options->clear();
Smach::event_result
StateGradient_Context::event_stop_handler(const Smach::event& /*x*/)
{
- throw Smach::egress_exception();
+ //throw Smach::egress_exception();
+ throw &state_normal;
+ return Smach::RESULT_OK;
}
Smach::event_result
void set_constrain_flag(bool x) { checkbutton_constrain.set_active(x); refresh_constrain_flag(); }
void refresh_constrain_flag() { if(duck_dragger_)duck_dragger_->constrain=get_constrain_flag(); }
- Smach::event_result event_refresh_tool_options(const Smach::event& x);
- void refresh_tool_options();
-
StateNormal_Context(CanvasView* canvas_view);
~StateNormal_Context();
bool key_pressed(GdkEventKey *event);
bool key_released(GdkEventKey *event);
+ Smach::event_result event_stop_handler(const Smach::event& x);
+ Smach::event_result event_refresh_handler(const Smach::event& x);
+ Smach::event_result event_refresh_ducks_handler(const Smach::event& x);
+ Smach::event_result event_undo_handler(const Smach::event& x);
+ Smach::event_result event_redo_handler(const Smach::event& x);
+ Smach::event_result event_mouse_button_down_handler(const Smach::event& x);
+ Smach::event_result event_multiple_ducks_clicked_handler(const Smach::event& x);
+ Smach::event_result event_refresh_tool_options(const Smach::event& x);
+ void refresh_tool_options();
+ Smach::event_result event_layer_click(const Smach::event& x);
+
+
}; // END of class StateNormal_Context
/* === M E T H O D S ======================================================= */
StateNormal::StateNormal():
Smach::state<StateNormal_Context>("normal")
{
+ insert(event_def(EVENT_STOP,&StateNormal_Context::event_stop_handler));
+ insert(event_def(EVENT_REFRESH,&StateNormal_Context::event_refresh_handler));
+ insert(event_def(EVENT_REFRESH_DUCKS,&StateNormal_Context::event_refresh_ducks_handler));
+ insert(event_def(EVENT_UNDO,&StateNormal_Context::event_undo_handler));
+ insert(event_def(EVENT_REDO,&StateNormal_Context::event_redo_handler));
+ insert(event_def(EVENT_WORKAREA_MOUSE_BUTTON_DOWN,&StateNormal_Context::event_mouse_button_down_handler));
+ insert(event_def(EVENT_WORKAREA_MULTIPLE_DUCKS_CLICKED,&StateNormal_Context::event_multiple_ducks_clicked_handler));
insert(event_def(EVENT_REFRESH_TOOL_OPTIONS,&StateNormal_Context::event_refresh_tool_options));
+ insert(event_def(EVENT_WORKAREA_LAYER_CLICKED,&StateNormal_Context::event_layer_click));
+
}
StateNormal::~StateNormal()
options_table.show_all();
refresh_tool_options();
//App::dialog_tool_options->set_widget(options_table);
- App::dialog_tool_options->present();
+ //App::dialog_tool_options->present();
get_work_area()->set_allow_layer_clicks(true);
get_work_area()->set_duck_dragger(duck_dragger_);
keypress_connect=get_work_area()->signal_key_press_event().connect(sigc::mem_fun(*this,&StateNormal_Context::key_pressed),false);
keyrelease_connect=get_work_area()->signal_key_release_event().connect(sigc::mem_fun(*this,&StateNormal_Context::key_released),false);
-// get_canvas_view()->work_area->set_cursor(Gdk::CROSSHAIR);
- get_canvas_view()->work_area->reset_cursor();
+ //these will segfault
+// get_work_area()->set_cursor(Gdk::CROSSHAIR);
+// get_work_area()->reset_cursor();
App::toolbox->refresh();
save_settings();
get_work_area()->clear_duck_dragger();
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
keypress_connect.disconnect();
keyrelease_connect.disconnect();
App::toolbox->refresh();
}
-
-Smach::event_result
-StateNormal_Context::event_refresh_tool_options(const Smach::event& /*x*/)
-{
- refresh_tool_options();
- return Smach::RESULT_ACCEPT;
-}
-
DuckDrag_Combo::DuckDrag_Combo():
scale(false),
rotate(false),
return false;
}
}
+
+Smach::event_result
+StateNormal_Context::event_refresh_tool_options(const Smach::event& /*x*/)
+{
+ refresh_tool_options();
+ return Smach::RESULT_ACCEPT;
+}
+
+Smach::event_result
+StateNormal_Context::event_stop_handler(const Smach::event& /*x*/)
+{
+ // synfig::info("STATE NORMAL: Received Stop Event");
+ canvas_view_->stop();
+ return Smach::RESULT_ACCEPT;
+}
+
+Smach::event_result
+StateNormal_Context::event_refresh_handler(const Smach::event& /*x*/)
+{
+ // synfig::info("STATE NORMAL: Received Refresh Event");
+ canvas_view_->rebuild_tables();
+ canvas_view_->work_area->queue_render_preview();
+ return Smach::RESULT_ACCEPT;
+}
+
+Smach::event_result
+StateNormal_Context::event_refresh_ducks_handler(const Smach::event& /*x*/)
+{
+ // synfig::info("STATE NORMAL: Received Refresh Ducks");
+ canvas_view_->queue_rebuild_ducks();
+ return Smach::RESULT_ACCEPT;
+}
+
+Smach::event_result
+StateNormal_Context::event_undo_handler(const Smach::event& /*x*/)
+{
+ // synfig::info("STATE NORMAL: Received Undo Event");
+ canvas_view_->get_instance()->undo();
+ return Smach::RESULT_ACCEPT;
+}
+
+Smach::event_result
+StateNormal_Context::event_redo_handler(const Smach::event& /*x*/)
+{
+ // synfig::info("STATE NORMAL: Received Redo Event");
+ canvas_view_->get_instance()->redo();
+ return Smach::RESULT_ACCEPT;
+}
+
+Smach::event_result
+StateNormal_Context::event_mouse_button_down_handler(const Smach::event& x)
+{
+ // synfig::info("STATE NORMAL: Received mouse button down Event");
+
+ const EventMouse& event(*reinterpret_cast<const EventMouse*>(&x));
+
+ switch(event.button)
+ {
+ case BUTTON_RIGHT:
+ canvas_view_->popup_main_menu();
+ return Smach::RESULT_ACCEPT;
+ default:
+ return Smach::RESULT_OK;
+ }
+}
+
+Smach::event_result
+StateNormal_Context::event_layer_click(const Smach::event& x)
+{
+ const EventLayerClick& event(*reinterpret_cast<const EventLayerClick*>(&x));
+
+ if(event.layer)
+ {
+ // synfig::info("STATE NORMAL: Received layer click Event, \"%s\"",event.layer->get_name().c_str());
+ }
+ else
+ {
+ // synfig::info("STATE NORMAL: Received layer click Event with an empty layer.");
+ }
+
+ switch(event.button)
+ {
+ case BUTTON_LEFT:
+ if(!(event.modifier&Gdk::CONTROL_MASK))
+ canvas_view_->get_selection_manager()->clear_selected_layers();
+ if(event.layer)
+ {
+ std::list<Layer::Handle> layer_list(canvas_view_->get_selection_manager()->get_selected_layers());
+ std::set<Layer::Handle> layers(layer_list.begin(),layer_list.end());
+ if(layers.count(event.layer))
+ {
+ layers.erase(event.layer);
+ layer_list=std::list<Layer::Handle>(layers.begin(),layers.end());
+ canvas_view_->get_selection_manager()->clear_selected_layers();
+ canvas_view_->get_selection_manager()->set_selected_layers(layer_list);
+ }
+ else
+ {
+ canvas_view_->get_selection_manager()->set_selected_layer(event.layer);
+ }
+ }
+ return Smach::RESULT_ACCEPT;
+ case BUTTON_RIGHT:
+ canvas_view_->popup_layer_menu(event.layer);
+ return Smach::RESULT_ACCEPT;
+ default:
+ return Smach::RESULT_OK;
+ }
+}
+
+/*
+void
+StateNormal_Context::edit_several_waypoints(std::list<synfigapp::ValueDesc> value_desc_list)
+{
+ Gtk::Dialog dialog(
+ "Edit Multiple Waypoints", // Title
+ true, // Modal
+ true // use_separator
+ );
+
+ Widget_WaypointModel widget_waypoint_model;
+ widget_waypoint_model.show();
+
+ dialog.get_vbox()->pack_start(widget_waypoint_model);
+
+
+ dialog.add_button(Gtk::StockID("gtk-apply"),1);
+ dialog.add_button(Gtk::StockID("gtk-cancel"),0);
+ dialog.show();
+
+ if(dialog.run()==0)
+ return;
+ synfigapp::Action::PassiveGrouper group(get_canvas_interface()->get_instance().get(),_("Set Waypoints"));
+
+ std::list<synfigapp::ValueDesc>::iterator iter;
+ for(iter=value_desc_list.begin();iter!=value_desc_list.end();++iter)
+ {
+ synfigapp::ValueDesc value_desc(*iter);
+
+ if(!value_desc.is_valid())
+ continue;
+
+ ValueNode_Animated::Handle value_node;
+
+ // If this value isn't a ValueNode_Animated, but
+ // it is somewhat constant, then go ahead and convert
+ // it to a ValueNode_Animated.
+ if(!value_desc.is_value_node() || ValueNode_Const::Handle::cast_dynamic(value_desc.get_value_node()))
+ {
+ ValueBase value;
+ if(value_desc.is_value_node())
+ value=ValueNode_Const::Handle::cast_dynamic(value_desc.get_value_node())->get_value();
+ else
+ value=value_desc.get_value();
+
+ value_node=ValueNode_Animated::create(value,get_canvas()->get_time());
+
+ synfigapp::Action::Handle action;
+
+ if(!value_desc.is_value_node())
+ {
+ action=synfigapp::Action::create("ValueDescConnect");
+ action->set_param("dest",value_desc);
+ action->set_param("src",ValueNode::Handle(value_node));
+ }
+ else
+ {
+ action=synfigapp::Action::create("ValueNodeReplace");
+ action->set_param("dest",value_desc.get_value_node());
+ action->set_param("src",ValueNode::Handle(value_node));
+ }
+
+ action->set_param("canvas",get_canvas());
+ action->set_param("canvas_interface",get_canvas_interface());
+
+
+ if(!get_canvas_interface()->get_instance()->perform_action(action))
+ {
+ get_canvas_view()->get_ui_interface()->error(_("Unable to convert to animated waypoint"));
+ group.cancel();
+ return;
+ }
+ }
+ else
+ {
+ if(value_desc.is_value_node())
+ value_node=ValueNode_Animated::Handle::cast_dynamic(value_desc.get_value_node());
+ }
+
+
+ if(value_node)
+ {
+
+ synfigapp::Action::Handle action(synfigapp::Action::create("WaypointSetSmart"));
+
+ if(!action)
+ {
+ get_canvas_view()->get_ui_interface()->error(_("Unable to find WaypointSetSmart action"));
+ group.cancel();
+ return;
+ }
+
+
+ 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("time",get_canvas()->get_time());
+ action->set_param("model",widget_waypoint_model.get_waypoint_model());
+
+ if(!get_canvas_interface()->get_instance()->perform_action(action))
+ {
+ get_canvas_view()->get_ui_interface()->error(_("Unable to set a specific waypoint"));
+ group.cancel();
+ return;
+ }
+ }
+ else
+ {
+ //get_canvas_view()->get_ui_interface()->error(_("Unable to animate a specific valuedesc"));
+ //group.cancel();
+ //return;
+ }
+
+ }
+}
+*/
+
+Smach::event_result
+StateNormal_Context::event_multiple_ducks_clicked_handler(const Smach::event& /*x*/)
+{
+ // synfig::info("STATE NORMAL: Received multiple duck click event");
+
+ //const EventMouse& event(*reinterpret_cast<const EventMouse*>(&x));
+
+ std::list<synfigapp::ValueDesc> value_desc_list;
+
+ // Create a list of value_descs associated with selection
+ const DuckList selected_ducks(get_work_area()->get_selected_ducks());
+ DuckList::const_iterator iter;
+ for(iter=selected_ducks.begin();iter!=selected_ducks.end();++iter)
+ {
+ synfigapp::ValueDesc value_desc((*iter)->get_value_desc());
+
+ if(!value_desc.is_valid())
+ continue;
+
+ if(value_desc.get_value_type()==ValueBase::TYPE_BLINEPOINT && value_desc.is_value_node() && ValueNode_Composite::Handle::cast_dynamic(value_desc.get_value_node()))
+ {
+ value_desc_list.push_back(
+ synfigapp::ValueDesc(
+ ValueNode_Composite::Handle::cast_dynamic(value_desc.get_value_node())
+ ,ValueNode_Composite::Handle::cast_dynamic(value_desc.get_value_node())
+ ->get_link_index_from_name("point")
+ )
+ );
+ }
+ else
+ value_desc_list.push_back(value_desc);
+ }
+
+ Gtk::Menu *menu=manage(new Gtk::Menu());
+ menu->signal_hide().connect(sigc::bind(sigc::ptr_fun(&delete_widget), menu));
+
+ canvas_view_->get_instance()->make_param_menu(menu,canvas_view_->get_canvas(),value_desc_list);
+
+ /*
+ synfigapp::Action::ParamList param_list;
+ param_list=get_canvas_interface()->generate_param_list(value_desc_list);
+
+ canvas_view_->add_actions_to_menu(menu, param_list,synfigapp::Action::CATEGORY_VALUEDESC|synfigapp::Action::CATEGORY_VALUENODE);
+
+ menu->items().push_back(Gtk::Menu_Helpers::MenuElem(_("Edit Waypoints"),
+ sigc::bind(
+ sigc::mem_fun(
+ *this,
+ &studio::StateNormal_Context::edit_several_waypoints
+ ),
+ value_desc_list
+ )
+ ));
+ */
+ menu->popup(3,gtk_get_current_event_time());
+
+ return Smach::RESULT_ACCEPT;
+}
+
+
+++ /dev/null
-/* === S Y N F I G ========================================================= */
-/*! \file state_null.cpp
-** \brief Null State File
-**
-** $Id$
-**
-** \legal
-** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
-** Copyright (c) 2007, 2008 Chris Moore
-** Copyright (c) 2009 Nikita Kitaev
-**
-** 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.
-**
-** 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
-*/
-/* ========================================================================= */
-
-/* === H E A D E R S ======================================================= */
-
-#ifdef USING_PCH
-# include "pch.h"
-#else
-#ifdef HAVE_CONFIG_H
-# include <config.h>
-#endif
-
-#include "state_null.h"
-#include "workarea.h"
-#include "event_mouse.h"
-#include "event_layerclick.h"
-#include "toolbox.h"
-#include "dialog_tooloptions.h"
-#include <gtkmm/dialog.h>
-#include "widget_waypointmodel.h"
-#include <synfig/valuenode_animated.h>
-#include <synfig/valuenode_composite.h>
-#include <synfig/valuenode_const.h>
-#include "canvasview.h"
-#include "general.h"
-
-#endif
-
-/* === U S I N G =========================================================== */
-
-using namespace std;
-using namespace etl;
-using namespace synfig;
-using namespace studio;
-
-/* === M A C R O S ========================================================= */
-
-/* === G L O B A L S ======================================================= */
-
-StateNull studio::state_null;
-
-/* === C L A S S E S & S T R U C T S ======================================= */
-
-class studio::StateNull_Context : public sigc::trackable
-{
- CanvasView *canvas_view;
-
- CanvasView* get_canvas_view() { return canvas_view; }
- Canvas::Handle get_canvas() { return canvas_view->get_canvas(); }
- WorkArea* get_work_area() { return canvas_view->get_work_area(); }
- etl::handle<synfigapp::CanvasInterface> get_canvas_interface() { return canvas_view->canvas_interface(); }
-
- Gtk::Table options_table;
-
-public:
- StateNull_Context(CanvasView *canvas_view);
- ~StateNull_Context();
-
- Smach::event_result event_stop_handler(const Smach::event& x);
- Smach::event_result event_refresh_handler(const Smach::event& x);
- Smach::event_result event_refresh_ducks_handler(const Smach::event& x);
- Smach::event_result event_undo_handler(const Smach::event& x);
- Smach::event_result event_redo_handler(const Smach::event& x);
- Smach::event_result event_mouse_button_down_handler(const Smach::event& x);
- Smach::event_result event_multiple_ducks_clicked_handler(const Smach::event& x);
- Smach::event_result event_refresh_tool_options(const Smach::event& x);
- Smach::event_result event_layer_click(const Smach::event& x);
-
- void refresh_tool_options();
-}; // END of class StateNull_Context
-
-/* === P R O C E D U R E S ================================================= */
-
-/* === M E T H O D S ======================================================= */
-
-StateNull::StateNull():
- Smach::state<StateNull_Context>("null")
-{
- insert(event_def(EVENT_STOP,&StateNull_Context::event_stop_handler));
- insert(event_def(EVENT_REFRESH,&StateNull_Context::event_refresh_handler));
- insert(event_def(EVENT_REFRESH_DUCKS,&StateNull_Context::event_refresh_ducks_handler));
- insert(event_def(EVENT_UNDO,&StateNull_Context::event_undo_handler));
- insert(event_def(EVENT_REDO,&StateNull_Context::event_redo_handler));
- insert(event_def(EVENT_WORKAREA_MOUSE_BUTTON_DOWN,&StateNull_Context::event_mouse_button_down_handler));
- insert(event_def(EVENT_WORKAREA_MULTIPLE_DUCKS_CLICKED,&StateNull_Context::event_multiple_ducks_clicked_handler));
- insert(event_def(EVENT_REFRESH_TOOL_OPTIONS,&StateNull_Context::event_refresh_tool_options));
- insert(event_def(EVENT_WORKAREA_LAYER_CLICKED,&StateNull_Context::event_layer_click));
-}
-
-StateNull::~StateNull()
-{
-}
-
-StateNull_Context::StateNull_Context(CanvasView *canvas_view):
- canvas_view(canvas_view)
-{
- // Synfig Studio's default state is initialized in the canvas view constructor
- // As a result, it cannot reference canvas view or workarea when created
- // Other states need to reference the workarea,
- // so a null state was created to be the default
-
- options_table.attach(*manage(new Gtk::Label(_("Welcome to Synfig Studio"))), 0, 2, 0, 1, Gtk::EXPAND|Gtk::FILL, Gtk::EXPAND|Gtk::FILL, 0, 0);
- options_table.show_all();
- refresh_tool_options();
-}
-
-StateNull_Context::~StateNull_Context()
-{
-}
-
-void
-StateNull_Context::refresh_tool_options()
-{
- App::dialog_tool_options->clear();
- App::dialog_tool_options->set_widget(options_table);
- App::dialog_tool_options->set_local_name(_("Welcome to Synfig Studio"));
- App::dialog_tool_options->set_name("null");
-}
-
-Smach::event_result
-StateNull_Context::event_refresh_tool_options(const Smach::event& /*x*/)
-{
- refresh_tool_options();
- return Smach::RESULT_ACCEPT;
-}
-
-Smach::event_result
-StateNull_Context::event_stop_handler(const Smach::event& /*x*/)
-{
- // synfig::info("STATE NULL: Received Stop Event");
- canvas_view->stop();
- return Smach::RESULT_ACCEPT;
-}
-
-Smach::event_result
-StateNull_Context::event_refresh_handler(const Smach::event& /*x*/)
-{
- // synfig::info("STATE NULL: Received Refresh Event");
- canvas_view->rebuild_tables();
- canvas_view->work_area->queue_render_preview();
- return Smach::RESULT_ACCEPT;
-}
-
-Smach::event_result
-StateNull_Context::event_refresh_ducks_handler(const Smach::event& /*x*/)
-{
- // synfig::info("STATE NULL: Received Refresh Ducks");
- canvas_view->queue_rebuild_ducks();
- return Smach::RESULT_ACCEPT;
-}
-
-Smach::event_result
-StateNull_Context::event_undo_handler(const Smach::event& /*x*/)
-{
- // synfig::info("STATE NULL: Received Undo Event");
- canvas_view->get_instance()->undo();
- return Smach::RESULT_ACCEPT;
-}
-
-Smach::event_result
-StateNull_Context::event_redo_handler(const Smach::event& /*x*/)
-{
- // synfig::info("STATE NULL: Received Redo Event");
- canvas_view->get_instance()->redo();
- return Smach::RESULT_ACCEPT;
-}
-
-Smach::event_result
-StateNull_Context::event_mouse_button_down_handler(const Smach::event& x)
-{
- // synfig::info("STATE NULL: Received mouse button down Event");
-
- const EventMouse& event(*reinterpret_cast<const EventMouse*>(&x));
-
- switch(event.button)
- {
- case BUTTON_RIGHT:
- canvas_view->popup_main_menu();
- return Smach::RESULT_ACCEPT;
- default:
- return Smach::RESULT_OK;
- }
-}
-
-Smach::event_result
-StateNull_Context::event_layer_click(const Smach::event& x)
-{
- const EventLayerClick& event(*reinterpret_cast<const EventLayerClick*>(&x));
-
- if(event.layer)
- {
- // synfig::info("STATE NULL: Received layer click Event, \"%s\"",event.layer->get_name().c_str());
- }
- else
- {
- // synfig::info("STATE NULL: Received layer click Event with an empty layer.");
- }
-
- switch(event.button)
- {
- case BUTTON_LEFT:
- if(!(event.modifier&Gdk::CONTROL_MASK))
- canvas_view->get_selection_manager()->clear_selected_layers();
- if(event.layer)
- {
- std::list<Layer::Handle> layer_list(canvas_view->get_selection_manager()->get_selected_layers());
- std::set<Layer::Handle> layers(layer_list.begin(),layer_list.end());
- if(layers.count(event.layer))
- {
- layers.erase(event.layer);
- layer_list=std::list<Layer::Handle>(layers.begin(),layers.end());
- canvas_view->get_selection_manager()->clear_selected_layers();
- canvas_view->get_selection_manager()->set_selected_layers(layer_list);
- }
- else
- {
- canvas_view->get_selection_manager()->set_selected_layer(event.layer);
- }
- }
- return Smach::RESULT_ACCEPT;
- case BUTTON_RIGHT:
- canvas_view->popup_layer_menu(event.layer);
- return Smach::RESULT_ACCEPT;
- default:
- return Smach::RESULT_OK;
- }
-}
-
-/*
-void
-StateNull_Context::edit_several_waypoints(std::list<synfigapp::ValueDesc> value_desc_list)
-{
- Gtk::Dialog dialog(
- "Edit Multiple Waypoints", // Title
- true, // Modal
- true // use_separator
- );
-
- Widget_WaypointModel widget_waypoint_model;
- widget_waypoint_model.show();
-
- dialog.get_vbox()->pack_start(widget_waypoint_model);
-
-
- dialog.add_button(Gtk::StockID("gtk-apply"),1);
- dialog.add_button(Gtk::StockID("gtk-cancel"),0);
- dialog.show();
-
- if(dialog.run()==0)
- return;
- synfigapp::Action::PassiveGrouper group(get_canvas_interface()->get_instance().get(),_("Set Waypoints"));
-
- std::list<synfigapp::ValueDesc>::iterator iter;
- for(iter=value_desc_list.begin();iter!=value_desc_list.end();++iter)
- {
- synfigapp::ValueDesc value_desc(*iter);
-
- if(!value_desc.is_valid())
- continue;
-
- ValueNode_Animated::Handle value_node;
-
- // If this value isn't a ValueNode_Animated, but
- // it is somewhat constant, then go ahead and convert
- // it to a ValueNode_Animated.
- if(!value_desc.is_value_node() || ValueNode_Const::Handle::cast_dynamic(value_desc.get_value_node()))
- {
- ValueBase value;
- if(value_desc.is_value_node())
- value=ValueNode_Const::Handle::cast_dynamic(value_desc.get_value_node())->get_value();
- else
- value=value_desc.get_value();
-
- value_node=ValueNode_Animated::create(value,get_canvas()->get_time());
-
- synfigapp::Action::Handle action;
-
- if(!value_desc.is_value_node())
- {
- action=synfigapp::Action::create("ValueDescConnect");
- action->set_param("dest",value_desc);
- action->set_param("src",ValueNode::Handle(value_node));
- }
- else
- {
- action=synfigapp::Action::create("ValueNodeReplace");
- action->set_param("dest",value_desc.get_value_node());
- action->set_param("src",ValueNode::Handle(value_node));
- }
-
- action->set_param("canvas",get_canvas());
- action->set_param("canvas_interface",get_canvas_interface());
-
-
- if(!get_canvas_interface()->get_instance()->perform_action(action))
- {
- get_canvas_view()->get_ui_interface()->error(_("Unable to convert to animated waypoint"));
- group.cancel();
- return;
- }
- }
- else
- {
- if(value_desc.is_value_node())
- value_node=ValueNode_Animated::Handle::cast_dynamic(value_desc.get_value_node());
- }
-
-
- if(value_node)
- {
-
- synfigapp::Action::Handle action(synfigapp::Action::create("WaypointSetSmart"));
-
- if(!action)
- {
- get_canvas_view()->get_ui_interface()->error(_("Unable to find WaypointSetSmart action"));
- group.cancel();
- return;
- }
-
-
- 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("time",get_canvas()->get_time());
- action->set_param("model",widget_waypoint_model.get_waypoint_model());
-
- if(!get_canvas_interface()->get_instance()->perform_action(action))
- {
- get_canvas_view()->get_ui_interface()->error(_("Unable to set a specific waypoint"));
- group.cancel();
- return;
- }
- }
- else
- {
- //get_canvas_view()->get_ui_interface()->error(_("Unable to animate a specific valuedesc"));
- //group.cancel();
- //return;
- }
-
- }
-}
-*/
-
-Smach::event_result
-StateNull_Context::event_multiple_ducks_clicked_handler(const Smach::event& /*x*/)
-{
- // synfig::info("STATE NULL: Received multiple duck click event");
-
- //const EventMouse& event(*reinterpret_cast<const EventMouse*>(&x));
-
- std::list<synfigapp::ValueDesc> value_desc_list;
-
- // Create a list of value_descs associated with selection
- const DuckList selected_ducks(get_work_area()->get_selected_ducks());
- DuckList::const_iterator iter;
- for(iter=selected_ducks.begin();iter!=selected_ducks.end();++iter)
- {
- synfigapp::ValueDesc value_desc((*iter)->get_value_desc());
-
- if(!value_desc.is_valid())
- continue;
-
- if(value_desc.get_value_type()==ValueBase::TYPE_BLINEPOINT && value_desc.is_value_node() && ValueNode_Composite::Handle::cast_dynamic(value_desc.get_value_node()))
- {
- value_desc_list.push_back(
- synfigapp::ValueDesc(
- ValueNode_Composite::Handle::cast_dynamic(value_desc.get_value_node())
- ,ValueNode_Composite::Handle::cast_dynamic(value_desc.get_value_node())
- ->get_link_index_from_name("point")
- )
- );
- }
- else
- value_desc_list.push_back(value_desc);
- }
-
- Gtk::Menu *menu=manage(new Gtk::Menu());
- menu->signal_hide().connect(sigc::bind(sigc::ptr_fun(&delete_widget), menu));
-
- canvas_view->get_instance()->make_param_menu(menu,canvas_view->get_canvas(),value_desc_list);
-
- /*
- synfigapp::Action::ParamList param_list;
- param_list=get_canvas_interface()->generate_param_list(value_desc_list);
-
- canvas_view->add_actions_to_menu(menu, param_list,synfigapp::Action::CATEGORY_VALUEDESC|synfigapp::Action::CATEGORY_VALUENODE);
-
- menu->items().push_back(Gtk::Menu_Helpers::MenuElem(_("Edit Waypoints"),
- sigc::bind(
- sigc::mem_fun(
- *this,
- &studio::StateNull_Context::edit_several_waypoints
- ),
- value_desc_list
- )
- ));
- */
- menu->popup(3,gtk_get_current_event_time());
-
- return Smach::RESULT_ACCEPT;
-}
-
+++ /dev/null
-/* === S Y N F I G ========================================================= */
-/*! \file state_null.h
-** \brief Null State Header
-**
-** $Id$
-**
-** \legal
-** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
-** Copyright (c) 2009 Nikita Kitaev
-**
-** 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.
-**
-** 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
-*/
-/* ========================================================================= */
-
-/* === S T A R T =========================================================== */
-
-#ifndef __SYNFIG_STATE_NULL_H
-#define __SYNFIG_STATE_NULL_H
-
-/* === H E A D E R S ======================================================= */
-
-#include "smach.h"
-
-
-/* === M A C R O S ========================================================= */
-
-/* === T Y P E D E F S ===================================================== */
-
-/* === C L A S S E S & S T R U C T S ======================================= */
-
-namespace studio {
-
-class StateNull_Context;
-
-class StateNull : public Smach::state<StateNull_Context>
-{
-public:
- StateNull();
- ~StateNull();
-}; // END of class StateNull
-
-extern StateNull state_null;
-
-}; // END of namespace studio
-
-/* === E N D =============================================================== */
-
-#endif
#include <synfig/valuenode_bline.h>
#include "state_polygon.h"
+#include "state_normal.h"
#include "canvasview.h"
#include "workarea.h"
#include "app.h"
Smach::event_result event_layer_selection_changed_handler(const Smach::event& /*x*/)
{
if(egress_on_selection_change)
- throw Smach::egress_exception();
+ throw &state_normal; //throw Smach::egress_exception();
return Smach::RESULT_OK;
}
// Refresh the work area
get_work_area()->queue_draw();
- get_canvas_view()->work_area->set_cursor(Gdk::CROSSHAIR);
+ get_work_area()->set_cursor(Gdk::CROSSHAIR);
// Hide the tables if they are showing
prev_table_status=get_canvas_view()->tables_are_visible();
App::dialog_tool_options->clear();
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
// Enable the time bar
get_canvas_view()->set_sensitive_timebar(true);
StatePolygon_Context::refresh_ducks()
{
get_work_area()->clear_ducks();
+ get_work_area()->queue_draw();
if(polygon_point_list.empty()) return;
#include <synfig/valuenode_bline.h>
#include "state_rectangle.h"
+#include "state_normal.h"
#include "canvasview.h"
#include "workarea.h"
#include "app.h"
Smach::event_result event_layer_selection_changed_handler(const Smach::event& /*x*/)
{
if(egress_on_selection_change)
- throw Smach::egress_exception();
+ throw &state_normal; //throw Smach::egress_exception();
return Smach::RESULT_OK;
}
// Refresh the work area
get_work_area()->queue_draw();
- get_canvas_view()->work_area->set_cursor(Gdk::CROSSHAIR);
+ get_work_area()->set_cursor(Gdk::DOTBOX);
// Hide the tables if they are showing
//prev_table_status=get_canvas_view()->tables_are_visible();
// Restore layer clicking
get_work_area()->set_allow_layer_clicks(prev_workarea_layer_status_);
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
App::dialog_tool_options->clear();
Smach::event_result
StateRectangle_Context::event_stop_handler(const Smach::event& /*x*/)
{
- throw Smach::egress_exception();
+ //throw Smach::egress_exception();
+ throw &state_normal;
+ return Smach::RESULT_OK;
}
Smach::event_result
--- /dev/null
+/* === S Y N F I G ========================================================= */
+/*! \file state_rotate.cpp
+** \brief Template File
+**
+** $Id$
+**
+** \legal
+** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
+** Copyright (c) 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
+** published by the Free Software Foundation; either version 2 of
+** the License, or (at your option) any later version.
+**
+** 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
+*/
+/* ========================================================================= */
+
+/* === H E A D E R S ======================================================= */
+
+#ifdef USING_PCH
+# include "pch.h"
+#else
+#ifdef HAVE_CONFIG_H
+# include <config.h>
+#endif
+
+#include <gtkmm/dialog.h>
+#include <gtkmm/entry.h>
+
+#include <synfig/valuenode_dynamiclist.h>
+#include <synfigapp/action_system.h>
+
+#include "state_rotate.h"
+#include "state_normal.h"
+#include "canvasview.h"
+#include "workarea.h"
+#include "app.h"
+
+#include <synfigapp/action.h>
+#include "event_mouse.h"
+#include "event_layerclick.h"
+#include "toolbox.h"
+#include "dialog_tooloptions.h"
+#include <gtkmm/optionmenu.h>
+#include "duck.h"
+#include <synfig/angle.h>
+#include <synfigapp/main.h>
+
+#include "general.h"
+
+#endif
+
+/* === U S I N G =========================================================== */
+
+using namespace std;
+using namespace etl;
+using namespace synfig;
+using namespace studio;
+
+/* === M A C R O S ========================================================= */
+
+#ifndef EPSILON
+#define EPSILON 0.0000001
+#endif
+
+/* === G L O B A L S ======================================================= */
+
+StateRotate studio::state_rotate;
+
+/* === C L A S S E S & S T R U C T S ======================================= */
+
+class DuckDrag_Rotate : public DuckDrag_Base
+{
+
+ synfig::Vector last_rotate;
+ synfig::Vector drag_offset;
+ synfig::Vector center;
+ synfig::Vector snap;
+
+ Angle original_angle;
+ Real original_mag;
+
+ std::vector<synfig::Vector> positions;
+
+
+ bool bad_drag;
+ bool move_only;
+
+public:
+ etl::handle<CanvasView> canvas_view_;
+ bool use_magnitude;
+ DuckDrag_Rotate();
+ void begin_duck_drag(Duckmatic* duckmatic, const synfig::Vector& begin);
+ bool end_duck_drag(Duckmatic* duckmatic);
+ void duck_drag(Duckmatic* duckmatic, const synfig::Vector& vector);
+
+ etl::handle<synfigapp::CanvasInterface> get_canvas_interface()const{return canvas_view_->canvas_interface();}
+};
+
+
+class studio::StateRotate_Context : public sigc::trackable
+{
+ etl::handle<CanvasView> canvas_view_;
+ CanvasView::IsWorking is_working;
+
+ synfigapp::Settings& settings;
+
+ etl::handle<DuckDrag_Rotate> duck_dragger_;
+
+ Gtk::Table options_table;
+
+ Gtk::CheckButton checkbutton_scale;
+
+public:
+
+ bool get_scale_flag()const { return checkbutton_scale.get_active(); }
+ void set_scale_flag(bool x) { return checkbutton_scale.set_active(x); refresh_scale_flag(); }
+
+ Smach::event_result event_stop_handler(const Smach::event& x);
+ Smach::event_result event_refresh_tool_options(const Smach::event& x);
+
+ void refresh_tool_options();
+
+ void refresh_scale_flag() { if(duck_dragger_)duck_dragger_->use_magnitude=get_scale_flag(); }
+
+ StateRotate_Context(CanvasView* canvas_view);
+
+ ~StateRotate_Context();
+
+ const etl::handle<CanvasView>& get_canvas_view()const{return canvas_view_;}
+ etl::handle<synfigapp::CanvasInterface> get_canvas_interface()const{return canvas_view_->canvas_interface();}
+ synfig::Canvas::Handle get_canvas()const{return canvas_view_->get_canvas();}
+ WorkArea * get_work_area()const{return canvas_view_->get_work_area();}
+
+ void load_settings();
+ void save_settings();
+}; // END of class StateRotate_Context
+
+/* === M E T H O D S ======================================================= */
+
+StateRotate::StateRotate():
+ Smach::state<StateRotate_Context>("rotate")
+{
+ insert(event_def(EVENT_REFRESH_TOOL_OPTIONS,&StateRotate_Context::event_refresh_tool_options));
+ insert(event_def(EVENT_STOP,&StateRotate_Context::event_stop_handler));
+}
+
+StateRotate::~StateRotate()
+{
+}
+
+void
+StateRotate_Context::load_settings()
+{
+ String value;
+
+ if(settings.get_value("rotate.scale",value) && value=="0")
+ set_scale_flag(false);
+ else
+ set_scale_flag(true);
+}
+
+void
+StateRotate_Context::save_settings()
+{
+ settings.set_value("rotate.scale",get_scale_flag()?"1":"0");
+}
+
+StateRotate_Context::StateRotate_Context(CanvasView* canvas_view):
+ canvas_view_(canvas_view),
+ is_working(*canvas_view),
+ settings(synfigapp::Main::get_selected_input_device()->settings()),
+ duck_dragger_(new DuckDrag_Rotate()),
+ checkbutton_scale(_("Allow Scale"))
+{
+ duck_dragger_->canvas_view_=get_canvas_view();
+
+ // Set up the tool options dialog
+ options_table.attach(*manage(new Gtk::Label(_("Rotate Tool"))), 0, 2, 0, 1, Gtk::EXPAND|Gtk::FILL, Gtk::EXPAND|Gtk::FILL, 0, 0);
+ options_table.attach(checkbutton_scale, 0, 2, 1, 2, Gtk::EXPAND|Gtk::FILL, Gtk::EXPAND|Gtk::FILL, 0, 0);
+
+ checkbutton_scale.signal_toggled().connect(sigc::mem_fun(*this,&StateRotate_Context::refresh_scale_flag));
+
+ options_table.show_all();
+ refresh_tool_options();
+ //App::dialog_tool_options->set_widget(options_table);
+ App::dialog_tool_options->present();
+
+ get_work_area()->set_allow_layer_clicks(true);
+ get_work_area()->set_duck_dragger(duck_dragger_);
+
+ get_work_area()->set_cursor(Gdk::EXCHANGE);
+// get_work_area()->reset_cursor();
+
+ App::toolbox->refresh();
+
+ load_settings();
+ refresh_scale_flag();
+}
+
+void
+StateRotate_Context::refresh_tool_options()
+{
+ App::dialog_tool_options->clear();
+ App::dialog_tool_options->set_widget(options_table);
+ App::dialog_tool_options->set_local_name(_("Rotate Tool"));
+ App::dialog_tool_options->set_name("rotate");
+}
+
+Smach::event_result
+StateRotate_Context::event_refresh_tool_options(const Smach::event& /*x*/)
+{
+ refresh_tool_options();
+ return Smach::RESULT_ACCEPT;
+}
+
+Smach::event_result
+StateRotate_Context::event_stop_handler(const Smach::event& /*x*/)
+{
+ throw &state_normal;
+ return Smach::RESULT_OK;
+}
+
+StateRotate_Context::~StateRotate_Context()
+{
+ save_settings();
+
+ get_work_area()->clear_duck_dragger();
+ get_work_area()->reset_cursor();
+
+ App::dialog_tool_options->clear();
+
+ App::toolbox->refresh();
+}
+
+
+
+
+DuckDrag_Rotate::DuckDrag_Rotate()
+{
+ use_magnitude=true;
+}
+
+void
+DuckDrag_Rotate::begin_duck_drag(Duckmatic* duckmatic, const synfig::Vector& offset)
+{
+ last_rotate=Vector(1,1);
+
+ const DuckList selected_ducks(duckmatic->get_selected_ducks());
+ DuckList::const_iterator iter;
+
+/*
+ if(duckmatic->get_selected_ducks().size()<2)
+ {
+ bad_drag=true;
+ return;
+ }
+*/
+ bad_drag=false;
+
+ drag_offset=duckmatic->find_duck(offset)->get_trans_point();
+
+ //snap=drag_offset-duckmatic->snap_point_to_grid(drag_offset);
+ //snap=offset-drag_offset;
+ snap=Vector(0,0);
+
+ // Calculate center
+ Point vmin(100000000,100000000);
+ Point vmax(-100000000,-100000000);
+ //std::set<etl::handle<Duck> >::iterator iter;
+ positions.clear();
+ int i;
+ for(i=0,iter=selected_ducks.begin();iter!=selected_ducks.end();++iter,i++)
+ {
+ Point p((*iter)->get_trans_point());
+ vmin[0]=min(vmin[0],p[0]);
+ vmin[1]=min(vmin[1],p[1]);
+ vmax[0]=max(vmax[0],p[0]);
+ vmax[1]=max(vmax[1],p[1]);
+ positions.push_back(p);
+ }
+ center=(vmin+vmax)*0.5;
+ if((vmin-vmax).mag()<=EPSILON)
+ move_only=true;
+ else
+ move_only=false;
+
+
+ synfig::Vector vect(offset-center);
+ original_angle=Angle::tan(vect[1],vect[0]);
+ original_mag=vect.mag();
+}
+
+
+void
+DuckDrag_Rotate::duck_drag(Duckmatic* duckmatic, const synfig::Vector& vector)
+{
+ if(bad_drag)
+ return;
+
+ //std::set<etl::handle<Duck> >::iterator iter;
+ synfig::Vector vect(duckmatic->snap_point_to_grid(vector)-center+snap);
+
+ const DuckList selected_ducks(duckmatic->get_selected_ducks());
+ DuckList::const_iterator iter;
+
+ if(move_only)
+ {
+ int i;
+ for(i=0,iter=selected_ducks.begin();iter!=selected_ducks.end();++iter,i++)
+ {
+ if((*iter)->get_type()!=Duck::TYPE_VERTEX&&(*iter)->get_type()!=Duck::TYPE_POSITION)continue;
+
+ Vector p(positions[i]);
+
+ p[0]+=vect[0];
+ p[1]+=vect[1];
+ (*iter)->set_trans_point(p);
+ }
+ for(i=0,iter=selected_ducks.begin();iter!=selected_ducks.end();++iter,i++)
+ {
+ if(!((*iter)->get_type()!=Duck::TYPE_VERTEX&&(*iter)->get_type()!=Duck::TYPE_POSITION))continue;
+
+ Vector p(positions[i]);
+
+ p[0]+=vect[0];
+ p[1]+=vect[1];
+ (*iter)->set_trans_point(p);
+ }
+ return;
+ }
+
+ Angle::tan angle(vect[1],vect[0]);
+ angle=original_angle-angle;
+ Real mag(vect.mag()/original_mag);
+ Real sine(Angle::sin(angle).get());
+ Real cosine(Angle::cos(angle).get());
+
+ int i;
+ for(i=0,iter=selected_ducks.begin();iter!=selected_ducks.end();++iter,i++)
+ {
+ if((*iter)->get_type()!=Duck::TYPE_VERTEX&&(*iter)->get_type()!=Duck::TYPE_POSITION)continue;
+
+ Vector x(positions[i]-center),p;
+
+ p[0]=cosine*x[0]+sine*x[1];
+ p[1]=-sine*x[0]+cosine*x[1];
+ if(use_magnitude)p*=mag;
+ p+=center;
+ (*iter)->set_trans_point(p);
+ }
+ for(i=0,iter=selected_ducks.begin();iter!=selected_ducks.end();++iter,i++)
+ {
+ if(!((*iter)->get_type()!=Duck::TYPE_VERTEX&&(*iter)->get_type()!=Duck::TYPE_POSITION))continue;
+
+ Vector x(positions[i]-center),p;
+
+ p[0]=cosine*x[0]+sine*x[1];
+ p[1]=-sine*x[0]+cosine*x[1];
+ if(use_magnitude)p*=mag;
+ p+=center;
+ (*iter)->set_trans_point(p);
+ }
+
+ last_rotate=vect;
+ //snap=Vector(0,0);
+}
+
+bool
+DuckDrag_Rotate::end_duck_drag(Duckmatic* duckmatic)
+{
+ if(bad_drag)return false;
+ if(move_only)
+ {
+ synfigapp::Action::PassiveGrouper group(get_canvas_interface()->get_instance().get(),_("Move Duck"));
+ duckmatic->signal_edited_selected_ducks();
+ return true;
+ }
+
+ synfigapp::Action::PassiveGrouper group(get_canvas_interface()->get_instance().get(),_("Rotate Ducks"));
+
+ if((last_rotate-Vector(1,1)).mag()>0.0001)
+ {
+ duckmatic->signal_edited_selected_ducks();
+ return true;
+ }
+ else
+ {
+ duckmatic->signal_user_click_selected_ducks(0);
+ return false;
+ }
+}
--- /dev/null
+/* === S Y N F I G ========================================================= */
+/*! \file state_rotate.h
+** \brief Template Header
+**
+** $Id$
+**
+** \legal
+** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
+**
+** 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.
+**
+** 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
+*/
+/* ========================================================================= */
+
+/* === S T A R T =========================================================== */
+
+#ifndef __SYNFIG_STUDIO_STATE_ROTATE_H
+#define __SYNFIG_STUDIO_STATE_ROTATE_H
+
+/* === H E A D E R S ======================================================= */
+
+#include "smach.h"
+
+
+/* === M A C R O S ========================================================= */
+
+/* === T Y P E D E F S ===================================================== */
+
+/* === C L A S S E S & S T R U C T S ======================================= */
+
+namespace studio {
+
+class StateRotate_Context;
+
+class StateRotate : public Smach::state<StateRotate_Context>
+{
+public:
+ StateRotate();
+ ~StateRotate();
+}; // END of class StateRotate
+
+extern StateRotate state_rotate;
+
+}; // END of namespace studio
+
+/* === E N D =============================================================== */
+
+#endif
--- /dev/null
+/* === S Y N F I G ========================================================= */
+/*! \file state_scale.cpp
+** \brief Template File
+**
+** $Id$
+**
+** \legal
+** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
+** Copyright (c) 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
+** published by the Free Software Foundation; either version 2 of
+** the License, or (at your option) any later version.
+**
+** 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
+*/
+/* ========================================================================= */
+
+/* === H E A D E R S ======================================================= */
+
+#ifdef USING_PCH
+# include "pch.h"
+#else
+#ifdef HAVE_CONFIG_H
+# include <config.h>
+#endif
+
+#include <gtkmm/dialog.h>
+#include <gtkmm/entry.h>
+
+#include <synfig/valuenode_dynamiclist.h>
+#include <synfigapp/action_system.h>
+
+#include "state_scale.h"
+#include "state_normal.h"
+#include "canvasview.h"
+#include "workarea.h"
+#include "app.h"
+
+#include <synfigapp/action.h>
+#include "event_mouse.h"
+#include "event_layerclick.h"
+#include "toolbox.h"
+#include "dialog_tooloptions.h"
+#include <gtkmm/optionmenu.h>
+#include "duck.h"
+#include <synfigapp/main.h>
+
+#include "general.h"
+
+#endif
+
+/* === U S I N G =========================================================== */
+
+using namespace std;
+using namespace etl;
+using namespace synfig;
+using namespace studio;
+
+/* === M A C R O S ========================================================= */
+
+/* === G L O B A L S ======================================================= */
+
+StateScale studio::state_scale;
+
+/* === C L A S S E S & S T R U C T S ======================================= */
+
+class DuckDrag_Scale : public DuckDrag_Base
+{
+
+ synfig::Vector last_scale;
+ synfig::Vector drag_offset;
+ synfig::Vector center;
+ synfig::Vector snap;
+
+ std::vector<synfig::Vector> positions;
+
+ bool move_only;
+
+ bool bad_drag;
+public:
+ bool lock_aspect;
+ DuckDrag_Scale();
+ void begin_duck_drag(Duckmatic* duckmatic, const synfig::Vector& begin);
+ bool end_duck_drag(Duckmatic* duckmatic);
+ void duck_drag(Duckmatic* duckmatic, const synfig::Vector& vector);
+};
+
+
+class studio::StateScale_Context : public sigc::trackable
+{
+ etl::handle<CanvasView> canvas_view_;
+ CanvasView::IsWorking is_working;
+
+ synfigapp::Settings& settings;
+
+ etl::handle<DuckDrag_Scale> duck_dragger_;
+
+ Gtk::Table options_table;
+
+
+ Gtk::CheckButton checkbutton_aspect_lock;
+
+public:
+
+ bool get_aspect_lock_flag()const { return checkbutton_aspect_lock.get_active(); }
+ void set_aspect_lock_flag(bool x) { return checkbutton_aspect_lock.set_active(x); refresh_aspect_lock_flag(); }
+
+ void refresh_aspect_lock_flag() { if(duck_dragger_)duck_dragger_->lock_aspect=get_aspect_lock_flag(); }
+
+ Smach::event_result event_stop_handler(const Smach::event& x);
+ Smach::event_result event_refresh_tool_options(const Smach::event& x);
+
+ void refresh_tool_options();
+
+ StateScale_Context(CanvasView* canvas_view);
+
+ ~StateScale_Context();
+
+ const etl::handle<CanvasView>& get_canvas_view()const{return canvas_view_;}
+ etl::handle<synfigapp::CanvasInterface> get_canvas_interface()const{return canvas_view_->canvas_interface();}
+ synfig::Canvas::Handle get_canvas()const{return canvas_view_->get_canvas();}
+ WorkArea * get_work_area()const{return canvas_view_->get_work_area();}
+
+ void load_settings();
+ void save_settings();
+}; // END of class StateScale_Context
+
+/* === M E T H O D S ======================================================= */
+
+StateScale::StateScale():
+ Smach::state<StateScale_Context>("scale")
+{
+ insert(event_def(EVENT_REFRESH_TOOL_OPTIONS,&StateScale_Context::event_refresh_tool_options));
+ insert(event_def(EVENT_STOP,&StateScale_Context::event_stop_handler));
+}
+
+StateScale::~StateScale()
+{
+}
+
+void
+StateScale_Context::load_settings()
+{
+ String value;
+
+ if(settings.get_value("scale.lock_aspect",value) && value=="0")
+ set_aspect_lock_flag(false);
+ else
+ set_aspect_lock_flag(true);
+}
+
+void
+StateScale_Context::save_settings()
+{
+ settings.set_value("scale.lock_aspect",get_aspect_lock_flag()?"1":"0");
+}
+
+StateScale_Context::StateScale_Context(CanvasView* canvas_view):
+ canvas_view_(canvas_view),
+ is_working(*canvas_view),
+ settings(synfigapp::Main::get_selected_input_device()->settings()),
+ duck_dragger_(new DuckDrag_Scale()),
+ checkbutton_aspect_lock(_("Lock Aspect Ratio"))
+{
+ // Set up the tool options dialog
+ options_table.attach(*manage(new Gtk::Label(_("Scale Tool"))), 0, 2, 0, 1, Gtk::EXPAND|Gtk::FILL, Gtk::EXPAND|Gtk::FILL, 0, 0);
+ options_table.attach(checkbutton_aspect_lock, 0, 2, 1, 2, Gtk::EXPAND|Gtk::FILL, Gtk::EXPAND|Gtk::FILL, 0, 0);
+
+ checkbutton_aspect_lock.signal_toggled().connect(sigc::mem_fun(*this,&StateScale_Context::refresh_aspect_lock_flag));
+
+ options_table.show_all();
+ refresh_tool_options();
+ App::dialog_tool_options->present();
+
+ get_work_area()->set_allow_layer_clicks(true);
+ get_work_area()->set_duck_dragger(duck_dragger_);
+
+ get_work_area()->set_cursor(Gdk::SIZING);
+// get_work_area()->reset_cursor();
+
+ App::toolbox->refresh();
+
+ set_aspect_lock_flag(true);
+ load_settings();
+}
+
+void
+StateScale_Context::refresh_tool_options()
+{
+ App::dialog_tool_options->clear();
+ App::dialog_tool_options->set_widget(options_table);
+ App::dialog_tool_options->set_local_name(_("Scale Tool"));
+ App::dialog_tool_options->set_name("scale");
+}
+
+Smach::event_result
+StateScale_Context::event_refresh_tool_options(const Smach::event& /*x*/)
+{
+ refresh_tool_options();
+ return Smach::RESULT_ACCEPT;
+}
+
+Smach::event_result
+StateScale_Context::event_stop_handler(const Smach::event& /*x*/)
+{
+ throw &state_normal;
+ return Smach::RESULT_OK;
+}
+
+StateScale_Context::~StateScale_Context()
+{
+ save_settings();
+
+ get_work_area()->clear_duck_dragger();
+ get_work_area()->reset_cursor();
+
+ App::dialog_tool_options->clear();
+
+ App::toolbox->refresh();
+}
+
+
+
+
+DuckDrag_Scale::DuckDrag_Scale():
+ lock_aspect(true)
+{
+}
+
+#ifndef EPSILON
+#define EPSILON 0.0000001
+#endif
+
+void
+DuckDrag_Scale::begin_duck_drag(Duckmatic* duckmatic, const synfig::Vector& offset)
+{
+ last_scale=Vector(1,1);
+ const DuckList selected_ducks(duckmatic->get_selected_ducks());
+ DuckList::const_iterator iter;
+
+ //if(duckmatic->get_selected_ducks().size()<2)
+ //{
+ // bad_drag=true;
+// return;
+// }
+ bad_drag=false;
+
+ drag_offset=duckmatic->find_duck(offset)->get_trans_point();
+
+ //snap=drag_offset-duckmatic->snap_point_to_grid(drag_offset);
+ //snap=offset-drag_offset;
+ snap=Vector(0,0);
+
+ // Calculate center
+ Point vmin(100000000,100000000);
+ Point vmax(-100000000,-100000000);
+ //std::set<etl::handle<Duck> >::iterator iter;
+ positions.clear();
+ int i;
+ for(i=0,iter=selected_ducks.begin();iter!=selected_ducks.end();++iter,i++)
+ {
+ Point p((*iter)->get_trans_point());
+ vmin[0]=min(vmin[0],p[0]);
+ vmin[1]=min(vmin[1],p[1]);
+ vmax[0]=max(vmax[0],p[0]);
+ vmax[1]=max(vmax[1],p[1]);
+ positions.push_back(p);
+ }
+ if((vmin-vmax).mag()<=EPSILON)
+ move_only=true;
+ else
+ move_only=false;
+
+ center=(vmin+vmax)*0.5;
+}
+
+
+void
+DuckDrag_Scale::duck_drag(Duckmatic* duckmatic, const synfig::Vector& vector)
+{
+ const DuckList selected_ducks(duckmatic->get_selected_ducks());
+ DuckList::const_iterator iter;
+
+ if(bad_drag)
+ return;
+
+ //std::set<etl::handle<Duck> >::iterator iter;
+ synfig::Vector vect(duckmatic->snap_point_to_grid(vector)-center);
+ last_scale=vect;
+
+ if(move_only)
+ {
+ int i;
+ for(i=0,iter=selected_ducks.begin();iter!=selected_ducks.end();++iter,i++)
+ {
+ if(((*iter)->get_type()!=Duck::TYPE_VERTEX&&(*iter)->get_type()!=Duck::TYPE_POSITION))continue;
+
+ Vector p(positions[i]);
+
+ p[0]+=vect[0];
+ p[1]+=vect[1];
+ (*iter)->set_trans_point(p);
+ }
+ for(i=0,iter=selected_ducks.begin();iter!=selected_ducks.end();++iter,i++)
+ {
+ if(!((*iter)->get_type()!=Duck::TYPE_VERTEX&&(*iter)->get_type()!=Duck::TYPE_POSITION))continue;
+
+ Vector p(positions[i]);
+
+ p[0]+=vect[0];
+ p[1]+=vect[1];
+ (*iter)->set_trans_point(p);
+ }
+ return;
+ }
+
+ if(!lock_aspect)
+ {
+ if(abs(drag_offset[0]-center[0])>EPSILON)
+ vect[0]/=drag_offset[0]-center[0];
+ else
+ vect[0]=1;
+ if(abs(drag_offset[1]-center[1])>EPSILON)
+ vect[1]/=drag_offset[1]-center[1];
+ else
+ vect[1]=1;
+ }
+ else
+ {
+ //vect[0]=vect[1]=vect.mag()*0.707106781;
+ Real amount(vect.mag()/(drag_offset-center).mag());
+ vect[0]=vect[1]=amount;
+ }
+
+ if(vect[0]<EPSILON && vect[0]>-EPSILON)
+ vect[0]=1;
+ if(vect[1]<EPSILON && vect[1]>-EPSILON)
+ vect[1]=1;
+
+ int i;
+ for(i=0,iter=selected_ducks.begin();iter!=selected_ducks.end();++iter,i++)
+ {
+ if(((*iter)->get_type()!=Duck::TYPE_VERTEX&&(*iter)->get_type()!=Duck::TYPE_POSITION))continue;
+
+ Vector p(positions[i]-center);
+
+ p[0]*=vect[0];
+ p[1]*=vect[1];
+ p+=center;
+ (*iter)->set_trans_point(p);
+ }
+ for(i=0,iter=selected_ducks.begin();iter!=selected_ducks.end();++iter,i++)
+ {
+ if(!((*iter)->get_type()!=Duck::TYPE_VERTEX&&(*iter)->get_type()!=Duck::TYPE_POSITION))continue;
+
+ Vector p(positions[i]-center);
+
+ p[0]*=vect[0];
+ p[1]*=vect[1];
+ p+=center;
+ (*iter)->set_trans_point(p);
+ }
+
+ last_scale=vect;
+ //snap=Vector(0,0);
+}
+
+bool
+DuckDrag_Scale::end_duck_drag(Duckmatic* duckmatic)
+{
+ if(bad_drag)return false;
+
+ if((last_scale-Vector(1,1)).mag()>0.0001)
+ {
+ duckmatic->signal_edited_selected_ducks();
+ return true;
+ }
+ else
+ {
+ duckmatic->signal_user_click_selected_ducks(0);
+ return false;
+ }
+}
--- /dev/null
+/* === S Y N F I G ========================================================= */
+/*! \file state_scale.h
+** \brief Template Header
+**
+** $Id$
+**
+** \legal
+** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
+**
+** 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.
+**
+** 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
+*/
+/* ========================================================================= */
+
+/* === S T A R T =========================================================== */
+
+#ifndef __SYNFIG_STUDIO_STATE_SCALE_H
+#define __SYNFIG_STUDIO_STATE_SCALE_H
+
+/* === H E A D E R S ======================================================= */
+
+#include "smach.h"
+
+/* === M A C R O S ========================================================= */
+
+/* === T Y P E D E F S ===================================================== */
+
+/* === C L A S S E S & S T R U C T S ======================================= */
+
+namespace studio {
+
+class StateScale_Context;
+
+class StateScale : public Smach::state<StateScale_Context>
+{
+public:
+ StateScale();
+ ~StateScale();
+}; // END of class StateScale
+
+extern StateScale state_scale;
+
+}; // END of namespace studio
+
+/* === E N D =============================================================== */
+
+#endif
#include <synfig/valuenode_dynamiclist.h>
#include "state_sketch.h"
+#include "state_normal.h"
#include "state_stroke.h"
#include "canvasview.h"
#include "workarea.h"
// Turn off layer clicking
get_work_area()->set_allow_layer_clicks(false);
- get_canvas_view()->work_area->set_cursor(Gdk::PENCIL);
+ get_work_area()->set_cursor(Gdk::PENCIL);
// Turn off duck clicking
get_work_area()->set_allow_duck_clicks(false);
StateSketch_Context::~StateSketch_Context()
{
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
App::dialog_tool_options->clear();
Smach::event_result
StateSketch_Context::event_stop_handler(const Smach::event& /*x*/)
{
- throw Smach::egress_exception();
+ //throw Smach::egress_exception();
+ throw &state_normal;
+ return Smach::RESULT_OK;
}
Smach::event_result
#include <synfigapp/action_system.h>
#include "state_smoothmove.h"
+#include "state_normal.h"
#include "canvasview.h"
#include "workarea.h"
#include "app.h"
class studio::StateSmoothMove_Context : public sigc::trackable
{
etl::handle<CanvasView> canvas_view_;
+ CanvasView::IsWorking is_working;
//Duckmatic::Push duckmatic_push;
Smach::state<StateSmoothMove_Context>("smooth_move")
{
insert(event_def(EVENT_REFRESH_TOOL_OPTIONS,&StateSmoothMove_Context::event_refresh_tool_options));
+ insert(event_def(EVENT_STOP,&StateSmoothMove_Context::event_stop_handler));
}
StateSmoothMove::~StateSmoothMove()
StateSmoothMove_Context::StateSmoothMove_Context(CanvasView* canvas_view):
canvas_view_(canvas_view),
+ is_working(*canvas_view),
// duckmatic_push(get_work_area()),
settings(synfigapp::Main::get_selected_input_device()->settings()),
duck_dragger_(new DuckDrag_SmoothMove()),
App::toolbox->refresh();
-// get_canvas_view()->work_area->set_cursor(Gdk::CROSSHAIR);
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->set_cursor(Gdk::FLEUR);
+ //get_work_area()->reset_cursor();
load_settings();
}
return Smach::RESULT_ACCEPT;
}
+Smach::event_result
+StateSmoothMove_Context::event_stop_handler(const Smach::event& /*x*/)
+{
+ throw &state_normal;
+ return Smach::RESULT_OK;
+}
+
StateSmoothMove_Context::~StateSmoothMove_Context()
{
save_settings();
get_work_area()->clear_duck_dragger();
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
App::dialog_tool_options->clear();
#include <synfig/valuenode_bline.h>
#include "state_star.h"
+#include "state_normal.h"
#include "canvasview.h"
#include "workarea.h"
#include "app.h"
Smach::event_result event_layer_selection_changed_handler(const Smach::event& /*x*/)
{
if(egress_on_selection_change)
- throw Smach::egress_exception();
+ throw &state_normal; //throw Smach::egress_exception();
return Smach::RESULT_OK;
}
// Connect a signal
//get_work_area()->signal_user_click().connect(sigc::mem_fun(*this,&studio::StateStar_Context::on_user_click));
- get_canvas_view()->work_area->set_cursor(Gdk::CROSSHAIR);
+ get_work_area()->set_cursor(Gdk::STAR);
App::toolbox->refresh();
}
// Restore layer clicking
get_work_area()->set_allow_layer_clicks(prev_workarea_layer_status_);
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
App::dialog_tool_options->clear();
Smach::event_result
StateStar_Context::event_stop_handler(const Smach::event& /*x*/)
{
- throw Smach::egress_exception();
+ //throw Smach::egress_exception();
+ throw &state_normal;
+ return Smach::RESULT_OK;
}
Smach::event_result
#include <gtkmm/entry.h>
#include "state_text.h"
+#include "state_normal.h"
#include "canvasview.h"
#include "workarea.h"
#include "app.h"
Smach::event_result event_layer_selection_changed_handler(const Smach::event& /*x*/)
{
if(egress_on_selection_change)
- throw Smach::egress_exception();
+ throw &state_normal; //throw Smach::egress_exception();
return Smach::RESULT_OK;
}
// Connect a signal
//get_work_area()->signal_user_click().connect(sigc::mem_fun(*this,&studio::StateText_Context::on_user_click));
- get_canvas_view()->work_area->set_cursor(Gdk::CROSSHAIR);
+ get_work_area()->set_cursor(Gdk::XTERM);
App::toolbox->refresh();
}
// Restore layer clicking
get_work_area()->set_allow_layer_clicks(prev_workarea_layer_status_);
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
App::dialog_tool_options->clear();
Smach::event_result
StateText_Context::event_stop_handler(const Smach::event& /*x*/)
{
- throw Smach::egress_exception();
+ //throw Smach::egress_exception();
+ throw &state_normal;
+ return Smach::RESULT_OK;
}
Smach::event_result
#include <synfigapp/action_system.h>
#include "state_width.h"
+#include "state_normal.h"
#include "canvasview.h"
#include "workarea.h"
#include "app.h"
Smach::event_result
StateWidth_Context::event_stop_handler(const Smach::event& /*x*/)
{
- throw Smach::egress_exception();
+ //throw Smach::egress_exception();
+ throw &state_normal;
+ return Smach::RESULT_OK;
}
Smach::event_result
#include "state_zoom.h"
+#include "state_normal.h"
#include "event_mouse.h"
#include "canvasview.h"
#include "workarea.h"
// Connect a signal
//get_work_area()->signal_user_click().connect(sigc::mem_fun(*this,&studio::StateZoom_Context::on_user_click));
- get_canvas_view()->work_area->set_cursor(Gdk::CROSSHAIR);
+ get_work_area()->set_cursor(Gdk::CROSSHAIR);
App::toolbox->refresh();
}
{
// Restore layer clicking
get_work_area()->set_allow_layer_clicks(prev_workarea_layer_status_);
- get_canvas_view()->work_area->reset_cursor();
+ get_work_area()->reset_cursor();
// Enable the time bar
//get_canvas_view()->set_sensitive_timebar(true);
Smach::event_result
StateZoom_Context::event_stop_handler(const Smach::event& /*x*/)
{
- throw Smach::egress_exception();
+ //throw Smach::egress_exception();
+ throw &state_normal;
+ return Smach::RESULT_OK;
}
Smach::event_result