diff options
author | Robin Watts <robin.watts@artifex.com> | 2015-03-05 17:31:05 -0700 |
---|---|---|
committer | Robin Watts <robin.watts@artifex.com> | 2015-03-24 19:50:00 +0000 |
commit | 5f161e45d5daacb696d02b8fad23d0c23f5bc8bc (patch) | |
tree | 6e8d84a383d580ee38b23dfb345bc96d0ba1e63e /source/fitz/svg-device.c | |
parent | 563c482145d65c4006f5842c8860ab1b09f5a229 (diff) | |
download | mupdf-5f161e45d5daacb696d02b8fad23d0c23f5bc8bc.tar.xz |
Path rework for improved memory usage.
Firstly, we make the definition of the path structures local to
path.c. This is achieved by using an fz_path_processor function to
step through paths enumerating each section using callback functions.
Next, we extend the internal path representation to include other
section types, including quads, beziers with common control points
rectangles, horizontal, vertical and degenerate lines. We also roll
close path sections up into the previous sections commands.
The hairiest part of this is that fz_transform_path has to cope with
changing the path commands depending on the matrix. This is a
relatively rare operation though.
Diffstat (limited to 'source/fitz/svg-device.c')
-rw-r--r-- | source/fitz/svg-device.c | 78 |
1 files changed, 43 insertions, 35 deletions
diff --git a/source/fitz/svg-device.c b/source/fitz/svg-device.c index 4345c225..4461f79e 100644 --- a/source/fitz/svg-device.c +++ b/source/fitz/svg-device.c @@ -88,43 +88,51 @@ end_def(fz_context *ctx, svg_device *sdev) /* Helper functions */ static void +svg_path_moveto(fz_context *ctx, void *arg, float x, float y) +{ + fz_output *out = (fz_output *)arg; + + fz_printf(ctx, out, "M %g %g ", x, y); +} + +static void +svg_path_lineto(fz_context *ctx, void *arg, float x, float y) +{ + fz_output *out = (fz_output *)arg; + + fz_printf(ctx, out, "L %g %g ", x, y); +} + +static void +svg_path_curveto(fz_context *ctx, void *arg, float x1, float y1, float x2, float y2, float x3, float y3) +{ + fz_output *out = (fz_output *)arg; + + fz_printf(ctx, out, "C %g %g %g %g %g %g ", x1, y1, x2, y2, x3, y3); +} + +static void +svg_path_close(fz_context *ctx, void *arg) +{ + fz_output *out = (fz_output *)arg; + + fz_printf(ctx, out, "Z "); +} + +static const fz_path_processor svg_path_proc = +{ + svg_path_moveto, + svg_path_lineto, + svg_path_curveto, + svg_path_close +}; + +static void svg_dev_path(fz_context *ctx, svg_device *sdev, fz_path *path) { - fz_output *out = sdev->out; - float x, y; - int i, k; - fz_printf(ctx, out, " d=\""); - for (i = 0, k = 0; i < path->cmd_len; i++) - { - switch (path->cmds[i]) - { - case FZ_MOVETO: - x = path->coords[k++]; - y = path->coords[k++]; - fz_printf(ctx, out, "M %g %g ", x, y); - break; - case FZ_LINETO: - x = path->coords[k++]; - y = path->coords[k++]; - fz_printf(ctx, out, "L %g %g ", x, y); - break; - case FZ_CURVETO: - x = path->coords[k++]; - y = path->coords[k++]; - fz_printf(ctx, out, "C %g %g ", x, y); - x = path->coords[k++]; - y = path->coords[k++]; - fz_printf(ctx, out, "%g %g ", x, y); - x = path->coords[k++]; - y = path->coords[k++]; - fz_printf(ctx, out, "%g %g ", x, y); - break; - case FZ_CLOSE_PATH: - fz_printf(ctx, out, "Z "); - break; - } - } - fz_printf(ctx, out, "\""); + fz_printf(ctx, sdev->out, " d=\""); + fz_process_path(ctx, &svg_path_proc, sdev->out, path); + fz_printf(ctx, sdev->out, "\""); } static void |