X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fdevices%2Fpdf.c;h=ba92ed0cca6b95872d8613cd3470f30dd9d15f6e;hb=ecd7c7248b9a93163090bfe7512b2a53d8da6d95;hp=720abd19e165719ea64cdf65af00d725c617cef4;hpb=580c48fef10df9184cf2728338e89f7db0fef2f5;p=swftools.git diff --git a/lib/devices/pdf.c b/lib/devices/pdf.c index 720abd1..ba92ed0 100644 --- a/lib/devices/pdf.c +++ b/lib/devices/pdf.c @@ -24,6 +24,9 @@ #include #include #include +#include +#include "../os.h" +#include "../jpeg.h" #include "../types.h" #include "../mem.h" #include "../gfxdevice.h" @@ -43,11 +46,14 @@ int pdf_setparameter(gfxdevice_t*dev, const char*key, const char*value) void pdf_startpage(gfxdevice_t*dev, int width, int height) { internal_t*i = (internal_t*)dev->internal; - - i->tempfile = strdup("tmp.pdf"); - PDF_open_file(i->p, i->tempfile); - PDF_set_parameter(i->p, "usercoordinates", "true"); - PDF_set_parameter(i->p, "topdown", "true"); + + if(!i->tempfile) { + i->tempfile = strdup(mktempname(0)); + PDF_open_file(i->p, i->tempfile); + PDF_set_parameter(i->p, "usercoordinates", "true"); + PDF_set_parameter(i->p, "topdown", "true"); + } + PDF_begin_page(i->p, width, height); PDF_set_parameter(i->p, "fillrule", "evenodd"); } @@ -88,7 +94,7 @@ void pdf_startclip(gfxdevice_t*dev, gfxline_t*line) if(mkline(line, i->p)) PDF_clip(i->p); else - ; // TODO: not sure about this + ; // TODO: strictly speaking, an empty clip clears everything } void pdf_endclip(gfxdevice_t*dev) @@ -124,8 +130,20 @@ void pdf_fillbitmap(gfxdevice_t*dev, gfxline_t*line, gfximage_t*img, gfxmatrix_t { internal_t*i = (internal_t*)dev->internal; - //PDFLIB_API int PDFLIB_CALL - //PDF_load_image(i->pPDF *p, const char *imagetype, const char *filename, int len, const char *optlist); + double l1 = sqrt(matrix->m00*matrix->m00+matrix->m01*matrix->m01)*img->width; + double l2 = sqrt(matrix->m10*matrix->m10+matrix->m11*matrix->m11)*img->height; + double r = atan2(matrix->m01, matrix->m00); + + /* fit_image needs the lower left corner of the image */ + double x = matrix->tx + matrix->m10*img->height; + double y = matrix->ty + matrix->m11*img->height; + + char*tempfile = mktempname(0); + char options[80]; + sprintf(options, "boxsize {%f %f} fitmethod meet rotate %f", l1, l2, r*180/M_PI); + gfximage_save_jpeg(img, tempfile, 99); + int imgid = PDF_load_image(i->p, "jpeg", tempfile, 0, ""); + PDF_fit_image(i->p, imgid, x, y, options); } void pdf_fillgradient(gfxdevice_t*dev, gfxline_t*line, gfxgradient_t*gradient, gfxgradienttype_t type, gfxmatrix_t*matrix) @@ -169,8 +187,6 @@ void pdf_endpage(gfxdevice_t*dev) { internal_t*i = (internal_t*)dev->internal; PDF_end_page(i->p); - PDF_close(i->p); - PDF_delete(i->p); } typedef struct pdfresult_internal { @@ -212,6 +228,9 @@ void* pdfresult_get(gfxresult_t*gfx, const char*name) gfxresult_t* pdf_finish(gfxdevice_t*dev) { internal_t*i = (internal_t*)dev->internal; + + PDF_close(i->p); + PDF_delete(i->p); gfxresult_t*result = (gfxresult_t*)malloc(sizeof(gfxresult_t)); memset(result, 0, sizeof(gfxresult_t));