X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=sym-text.c;h=96b3a50cd7a8d0fdb4a31308ac2f36651882c158;hb=63549401134446b1ffedc1e128ba9e4e045451fd;hp=3188938a38fd151c92998fce6005a493b3cb7904;hpb=4e51953df82e9ed1797912c2ecb17098a3253452;p=leo.git diff --git a/sym-text.c b/sym-text.c index 3188938..96b3a50 100644 --- a/sym-text.c +++ b/sym-text.c @@ -7,6 +7,7 @@ #include #include +#include #include #include #include FT_FREETYPE_H @@ -227,7 +228,6 @@ static void prepare_text_element(struct sym_text *t, struct svg *svg) static void sym_text_draw(struct symbol *sym, struct svg *svg) { struct sym_text *t = (struct sym_text *) sym; -printf("Drawing %s at [%.2f; %.2f]\n", osm_val_decode(t->text), t->x, t->y); if (t->next_duplicate) { @@ -244,10 +244,16 @@ printf("Drawing %s at [%.2f; %.2f]\n", osm_val_decode(t->text), t->x, t->y); t->y = sy / nn; } - if (t->opacity != 1) + bool use_group = 0; + bool want_rotate = (fabs(t->rotate) > 1e-5); + if (t->opacity != 1 || want_rotate) { + use_group = 1; svg_push_element(svg, "g"); - svg_set_attr_float(svg, "opacity", t->opacity); + if (t->opacity != 1) + svg_set_attr_float(svg, "opacity", t->opacity); + if (want_rotate) + svg_set_attr_format(svg, "transform", "rotate(%.2f %s %s)", -t->rotate, svg_format_dimen(svg, t->x), svg_format_dimen(svg, t->y)); } if (t->halo_radius) @@ -295,7 +301,7 @@ printf("Drawing %s at [%.2f; %.2f]\n", osm_val_decode(t->text), t->x, t->y); svg_pop(svg); #endif - if (t->opacity != 1) + if (use_group) svg_pop(svg); } @@ -460,14 +466,10 @@ static void sym_text_center(struct osm_object *o, struct style_info *si, osm_val text_fix_placement(st); if (o->type == OSM_TYPE_WAY && !osm_way_cyclic_p((struct osm_way *) o)) { - //sym_plan(&st->s, sym_zindex(o, si, 4.9)); - printf("[Sym] Labelling way %ju with %s\n", o->id, osm_val_decode(st->text)); labeller_add_linelabel(&st->s, o, sym_zindex(o, si, 4.9)); } else { - //sym_plan(&st->s, sym_zindex(o, si, 4.9)); - printf("[Sym] Labelling area %ju with %s\n", o->id, osm_val_decode(st->text)); labeller_add_arealabel(&st->s, o, sym_zindex(o, si, 4.9)); } }