From c00887bd18e0f0162db2e7c074028aeb714450a7 Mon Sep 17 00:00:00 2001 From: ellson Date: Thu, 24 May 2007 11:16:25 +0000 Subject: [PATCH] add -Tvml support from: seth@swoolley.homeip.net --- plugin/core/Makefile.am | 1 + plugin/core/gvplugin_core.c | 2 + plugin/core/gvrender_core_vml.c | 431 ++++++++++++++++++++++++++++++++ 3 files changed, 434 insertions(+) create mode 100644 plugin/core/gvrender_core_vml.c diff --git a/plugin/core/Makefile.am b/plugin/core/Makefile.am index 27ac0b064..0f42e19d3 100644 --- a/plugin/core/Makefile.am +++ b/plugin/core/Makefile.am @@ -21,6 +21,7 @@ libgvplugin_core_C_la_SOURCES = \ gvrender_core_ps.c \ gvrender_core_fig.c \ gvrender_core_svg.c \ + gvrender_core_vml.c \ gvrender_core_map.c \ gvloadimage_core.c diff --git a/plugin/core/gvplugin_core.c b/plugin/core/gvplugin_core.c index f5ee99c99..8c45a0305 100644 --- a/plugin/core/gvplugin_core.c +++ b/plugin/core/gvplugin_core.c @@ -20,6 +20,7 @@ extern gvplugin_installed_t gvrender_core_dot_types; extern gvplugin_installed_t gvrender_core_ps_types; extern gvplugin_installed_t gvrender_core_fig_types; extern gvplugin_installed_t gvrender_core_svg_types; +extern gvplugin_installed_t gvrender_core_vml_types; extern gvplugin_installed_t gvrender_core_map_types; extern gvplugin_installed_t gvloadimage_core_types; @@ -28,6 +29,7 @@ static gvplugin_api_t apis[] = { {API_render, &gvrender_core_ps_types}, {API_render, &gvrender_core_fig_types}, {API_render, &gvrender_core_svg_types}, + {API_render, &gvrender_core_vml_types}, {API_render, &gvrender_core_map_types}, {API_loadimage, &gvloadimage_core_types}, {(api_t)0, 0}, diff --git a/plugin/core/gvrender_core_vml.c b/plugin/core/gvrender_core_vml.c new file mode 100644 index 000000000..7b3f9eee5 --- /dev/null +++ b/plugin/core/gvrender_core_vml.c @@ -0,0 +1,431 @@ +/* $Id$ $Revision$ */ +/* vim:set shiftwidth=4 ts=8: */ + +/********************************************************** +* This software is part of the graphviz package * +* http://www.graphviz.org/ * +* * +* Copyright (c) 1994-2004 AT&T Corp. * +* and is licensed under the * +* Common Public License, Version 1.0 * +* by AT&T Corp. * +* * +* Information and Software Systems Research * +* AT&T Research, Florham Park NJ * +**********************************************************/ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include +#include +#include + +#include "macros.h" +#include "const.h" + +#include "gvplugin_render.h" +#include "graph.h" + +typedef enum { FORMAT_VML, FORMAT_VMLZ, } format_type; + +extern char *xml_string(char *str); +extern void core_init_compression(GVJ_t * job, compression_t compression); +extern void core_fini_compression(GVJ_t * job); +extern void core_fputs(GVJ_t * job, char *s); +extern void core_printf(GVJ_t * job, const char *format, ...); + +char graphcoords[256]; + +static void vml_bzptarray(GVJ_t * job, pointf * A, int n) +{ + int i; + char *c; + + c = "m "; /* first point */ + for (i = 0; i < n; i++) { + core_printf(job, "%s%.0f,%.0f ", c, A[i].x, -A[i].y); + if (i == 0) + c = "c "; /* second point */ + else + c = ""; /* remaining points */ + } +} + +static void vml_print_color(GVJ_t * job, gvcolor_t color) +{ + switch (color.type) { + case COLOR_STRING: + core_fputs(job, color.u.string); + break; + case RGBA_BYTE: + if (color.u.rgba[3] == 0) /* transparent */ + core_fputs(job, "none"); + else + core_printf(job, "#%02x%02x%02x", + color.u.rgba[0], color.u.rgba[1], color.u.rgba[2]); + break; + default: + assert(0); /* internal error */ + } +} + +static void vml_grstroke(GVJ_t * job, int filled) +{ + obj_state_t *obj = job->obj; + + core_fputs(job, "fillcolor); + else + core_fputs(job, "none"); + core_fputs(job, "\" strokecolor=\""); + vml_print_color(job, obj->pencolor); + if (obj->penwidth != PENWIDTH_NORMAL) + core_printf(job, "\" stroke-weight=\"%g", obj->penwidth); + if (obj->pen == PEN_DASHED) { + core_fputs(job, "\" dashstyle=\"dash"); + } else if (obj->pen == PEN_DOTTED) { + core_fputs(job, "\" dashstyle=\"dot"); + } + core_fputs(job, "\" />"); +} + +static void vml_grstrokeattr(GVJ_t * job) +{ + obj_state_t *obj = job->obj; + + core_fputs(job, " strokecolor=\""); + vml_print_color(job, obj->pencolor); + if (obj->penwidth != PENWIDTH_NORMAL) + core_printf(job, "\" stroke-weight=\"%g", obj->penwidth); + if (obj->pen == PEN_DASHED) { + core_fputs(job, "\" dashstyle=\"dash"); + } else if (obj->pen == PEN_DOTTED) { + core_fputs(job, "\" dashstyle=\"dot"); + } + core_fputs(job, "\""); +} + +static void vml_grfill(GVJ_t * job, int filled) +{ + obj_state_t *obj = job->obj; + + core_fputs(job, "fillcolor); + else + core_fputs(job, "none"); + core_fputs(job, "\" />"); +} + +static void vml_comment(GVJ_t * job, char *str) +{ + core_fputs(job, " \n"); +} + +static void vml_begin_job(GVJ_t * job) +{ + switch (job->render.id) { + case FORMAT_VMLZ: + core_init_compression(job, COMPRESSION_ZLIB); + break; + case FORMAT_VML: + core_init_compression(job, COMPRESSION_NONE); + break; + } + + core_fputs(job, "\n"); + + core_fputs(job, "\n"); + core_fputs(job, ""); + + core_fputs(job, "\n\n"); +} + +static void vml_begin_graph(GVJ_t * job) +{ + obj_state_t *obj = job->obj; + + core_fputs(job, ""); + if (obj->u.g->name[0]) { + core_fputs(job, ""); + core_fputs(job, xml_string(obj->u.g->name)); + core_fputs(job, ""); + } + core_printf(job, "\n\n", job->pagesArraySize.x * job->pagesArraySize.y); + + snprintf(graphcoords, sizeof(graphcoords), "style=\"width: %.0fpt; height: %.0fpt\" coordsize=\"%.0f,%.0f\" coordorigin=\"-4,-%.0f\"", + job->width*.75, job->height*.75, + job->width*.75, job->height*.75, + job->height*.75 - 4); + + core_printf(job, "\n
\n", graphcoords); + core_fputs(job, "\n"); +/* graphcoords[0] = '\0'; */ + +} + +static void vml_end_graph(GVJ_t * job) +{ + core_fputs(job, "
\n\n"); + core_fini_compression(job); +} + +static void +vml_begin_anchor(GVJ_t * job, char *href, char *tooltip, char *target) +{ + core_fputs(job, " \n"); +} + +static void vml_end_anchor(GVJ_t * job) +{ + core_fputs(job, " \n"); +} + +static void vml_textpara(GVJ_t * job, pointf p, textpara_t * para) +{ + obj_state_t *obj = job->obj; + + core_fputs(job, " just) { + case 'l': + core_fputs(job, " style=\"text-align: left; "); + break; + case 'r': + core_fputs(job, " style=\"text-align: right; "); + break; + default: + case 'n': + core_fputs(job, " style=\"text-align: center; "); + break; + } + core_printf(job, "position: absolute; left: %gpx; top: %gpx;", p.x/.75, job->height - p.y/.75 - 14); + if (para->postscript_alias) { + core_printf(job, " font-family: '%s';", para->postscript_alias->family); + if (para->postscript_alias->weight) + core_printf(job, " font-weight: %s;", para->postscript_alias->weight); + if (para->postscript_alias->stretch) + core_printf(job, " font-stretch: %s;", para->postscript_alias->stretch); + if (para->postscript_alias->style) + core_printf(job, " font-style: %s;", para->postscript_alias->style); + } + else { + core_printf(job, " font-family: \'%s\';", para->fontname); + } + /* FIXME - even inkscape requires a magic correction to fontsize. Why? */ + core_printf(job, " font-size: %.2fpt;", para->fontsize * 0.81); + switch (obj->pencolor.type) { + case COLOR_STRING: + if (strcasecmp(obj->pencolor.u.string, "black")) + core_printf(job, "color:%s;", obj->pencolor.u.string); + break; + case RGBA_BYTE: + core_printf(job, "color:#%02x%02x%02x;", + obj->pencolor.u.rgba[0], obj->pencolor.u.rgba[1], obj->pencolor.u.rgba[2]); + break; + default: + assert(0); /* internal error */ + } + core_fputs(job, "\">"); + core_fputs(job, xml_string(para->str)); + core_fputs(job, "\n"); +} + +static void vml_ellipse(GVJ_t * job, pointf * A, int filled) +{ + /* A[] contains 2 points: the center and corner. */ + + core_fputs(job, " height*.75 - A[1].y-4); + core_printf(job, " width: %gpt; height: %gpt;", 2*(A[1].x - A[0].x), 2*(A[1].y - A[0].y)); + core_fputs(job, "\">"); + vml_grstroke(job, filled); + vml_grfill(job, filled); + core_fputs(job, "\n"); +} + +static void +vml_bezier(GVJ_t * job, pointf * A, int n, int arrow_at_start, + int arrow_at_end, int filled) +{ + core_printf(job, " "); + vml_grstroke(job, filled); + core_fputs(job, ""); + vml_grfill(job, filled); + core_fputs(job, "\n"); +} + +static void vml_polygon(GVJ_t * job, pointf * A, int n, int filled) +{ + int i; + + core_fputs(job, " "); + vml_grstroke(job, filled); + core_fputs(job, ""); + vml_grfill(job, filled); + core_fputs(job, "\n"); +} + +static void vml_polyline(GVJ_t * job, pointf * A, int n) +{ + int i; + + core_printf(job, " "); + vml_grstroke(job, 0); /* no fill here for polyline */ + core_fputs(job, ""); + core_fputs(job, "\n"); + +} + +/* color names from http://www.w3.org/TR/VML/types.html */ +/* NB. List must be LANG_C sorted */ +static char *vml_knowncolors[] = { + "aliceblue", "antiquewhite", "aqua", "aquamarine", "azure", + "beige", "bisque", "black", "blanchedalmond", "blue", + "blueviolet", "brown", "burlywood", + "cadetblue", "chartreuse", "chocolate", "coral", + "cornflowerblue", "cornsilk", "crimson", "cyan", + "darkblue", "darkcyan", "darkgoldenrod", "darkgray", + "darkgreen", "darkgrey", "darkkhaki", "darkmagenta", + "darkolivegreen", "darkorange", "darkorchid", "darkred", + "darksalmon", "darkseagreen", "darkslateblue", "darkslategray", + "darkslategrey", "darkturquoise", "darkviolet", "deeppink", + "deepskyblue", "dimgray", "dimgrey", "dodgerblue", + "firebrick", "floralwhite", "forestgreen", "fuchsia", + "gainsboro", "ghostwhite", "gold", "goldenrod", "gray", + "green", "greenyellow", "grey", + "honeydew", "hotpink", "indianred", + "indigo", "ivory", "khaki", + "lavender", "lavenderblush", "lawngreen", "lemonchiffon", + "lightblue", "lightcoral", "lightcyan", "lightgoldenrodyellow", + "lightgray", "lightgreen", "lightgrey", "lightpink", + "lightsalmon", "lightseagreen", "lightskyblue", + "lightslategray", "lightslategrey", "lightsteelblue", + "lightyellow", "lime", "limegreen", "linen", + "magenta", "maroon", "mediumaquamarine", "mediumblue", + "mediumorchid", "mediumpurple", "mediumseagreen", + "mediumslateblue", "mediumspringgreen", "mediumturquoise", + "mediumvioletred", "midnightblue", "mintcream", + "mistyrose", "moccasin", + "navajowhite", "navy", "oldlace", + "olive", "olivedrab", "orange", "orangered", "orchid", + "palegoldenrod", "palegreen", "paleturquoise", + "palevioletred", "papayawhip", "peachpuff", "peru", "pink", + "plum", "powderblue", "purple", + "red", "rosybrown", "royalblue", + "saddlebrown", "salmon", "sandybrown", "seagreen", "seashell", + "sienna", "silver", "skyblue", "slateblue", "slategray", + "slategrey", "snow", "springgreen", "steelblue", + "tan", "teal", "thistle", "tomato", "turquoise", + "violet", + "wheat", "white", "whitesmoke", + "yellow", "yellowgreen" +}; + +gvrender_engine_t vml_engine = { + vml_begin_job, + 0, /* vml_end_job */ + vml_begin_graph, + vml_end_graph, + 0, /* vml_begin_layer */ + 0, /* vml_end_layer */ + 0, /* vml_begin_page */ + 0, /* vml_end_page */ + 0, /* vml_begin_cluster */ + 0, /* vml_end_cluster */ + 0, /* vml_begin_nodes */ + 0, /* vml_end_nodes */ + 0, /* vml_begin_edges */ + 0, /* vml_end_edges */ + 0, /* vml_begin_node */ + 0, /* vml_end_node */ + 0, /* vml_begin_edge */ + 0, /* vml_end_edge */ + vml_begin_anchor, + vml_end_anchor, + vml_textpara, + 0, /* vml_resolve_color */ + vml_ellipse, + vml_polygon, + vml_bezier, + vml_polyline, + vml_comment, + 0, /* vml_library_shape */ +}; + +gvrender_features_t vml_features = { + GVRENDER_DOES_TRUECOLOR + | GVRENDER_Y_GOES_DOWN + | GVRENDER_DOES_TRANSFORM + | GVRENDER_DOES_LABELS + | GVRENDER_DOES_MAPS + | GVRENDER_DOES_TARGETS + | GVRENDER_DOES_TOOLTIPS, /* flags */ + DEFAULT_EMBED_MARGIN, /* default margin - points */ + 4., /* default pad - graph units */ + {0.,0.}, /* default page width, height - points */ + {96.,96.}, /* default dpi */ + vml_knowncolors, /* knowncolors */ + sizeof(vml_knowncolors) / sizeof(char *), /* sizeof knowncolors */ + RGBA_BYTE, /* color_type */ + NULL, /* device */ + "vml", /* gvloadimage target for usershapes */ +}; + +gvplugin_installed_t gvrender_core_vml_types[] = { + {FORMAT_VML, "vml", 1, &vml_engine, &vml_features}, +#if HAVE_LIBZ + {FORMAT_VMLZ, "vmlz", 1, &vml_engine, &vml_features}, +#endif + {0, NULL, 0, NULL, NULL} +}; -- 2.40.0