blob: 068384822c1a58dc54883dc829acad329e49aeee [file] [log] [blame]
#include <cairo/cairo.h>
#include "pes.h"
#define X(stitch) (((stitch)->x - pes->min_x) * scale)
#define Y(stitch) (((stitch)->y - pes->min_y) * scale)
void output_cairo(struct pes *pes, const char *filename, int size, double density)
{
int width = pes->max_x - pes->min_x, outw;
int height = pes->max_y - pes->min_y, outh;
double scale = 1.0;
cairo_surface_t *surface;
cairo_t *cr;
if (size > 0) {
int maxd = width > height ? width : height;
scale = (double) size / maxd;
}
outw = width * scale;
outh = height * scale;
surface = cairo_image_surface_create (CAIRO_FORMAT_ARGB32, outw+1, outh+1);
cr = cairo_create (surface);
for (struct pes_block *block = pes->blocks; block; block = block->next) {
struct color *c = block->color;
struct stitch *stitch = block->stitch;
int i;
if (!block->nr_stitches)
continue;
cairo_set_source_rgb(cr, c->r / 255.0, c->g / 255.0, c->b / 255.0);
cairo_move_to(cr, X(stitch), Y(stitch));
for (i = 1; i < block->nr_stitches; i++) {
++stitch;
if(!stitch->jumpstitch) cairo_line_to(cr, X(stitch), Y(stitch));
else cairo_move_to(cr, X(stitch), Y(stitch));
}
cairo_set_line_width(cr, scale * density);
cairo_set_line_cap(cr, CAIRO_LINE_CAP_ROUND);
cairo_set_line_join(cr, CAIRO_LINE_JOIN_ROUND);
cairo_stroke(cr);
}
cairo_surface_write_to_png(surface, filename);
}