X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=pdf2swf%2Fpdf2swf.cc;h=143b867ea3a7fdc12b4b4e139d7827030acc42dd;hb=8e6c12f547bc9ccf1eaecb6fce4f48c47215d263;hp=a47b91d94d1856a59d3ef7fc02df3345a6356f2e;hpb=d6fa2d6b7a322aed5ffb0cc029cb9432ea64e8db;p=swftools.git diff --git a/pdf2swf/pdf2swf.cc b/pdf2swf/pdf2swf.cc index a47b91d..143b867 100644 --- a/pdf2swf/pdf2swf.cc +++ b/pdf2swf/pdf2swf.cc @@ -51,6 +51,7 @@ static char * password = 0; static char * preloader = 0; static char * viewer = 0; +static int nup = 0; char* fontpaths[256]; int fontpathpos = 0; @@ -90,6 +91,16 @@ int args_callback_option(char*name,char*val) { setConsoleLogging(loglevel); return 0; } + else if (!strcmp(name, "2")) + { + nup = 2; + return 0; + } + else if (!strcmp(name, "4")) + { + nup = 4; + return 0; + } else if (!strcmp(name, "q")) { loglevel --; @@ -333,6 +344,9 @@ void args_callback_usage(char*name) " graphic errors)\n"); printf("-s filloverlap Make intersecting shapes overlap, instead of canceling each\n" " other out. (Needed for some Powerpoint PDFs)\n"); + //deliberately undocumented (for now) + //printf("-2 Put 2 pages into each frame.\n"); + //printf("-4 Put 4 pages into each frame.\n"); printf("Postprocessing options:\n"); #ifndef SYSTEM_BACKTICKS printf("(They might not work because your system call doesn't support command substitution)\n"); @@ -369,6 +383,8 @@ int main(int argn, char *argv[]) int numfonts = 0; int t; char t1searchpath[1024]; + int nup_pos = 0; + int x,y; initLog(0,-1,0,0,-1,loglevel); @@ -440,9 +456,31 @@ int main(int argn, char *argv[]) } if(is_in_range(t, pagerange)) { pdf_page_t*page = pdf_getpage(pdf, t); - pdf_page_render(page, swf); + if(nup) { + pdf_page_info_t* info = pdf_page_getinfo(page); + if(nup_pos%nup == 0) { + pdf_page_render(page, swf); + x = info->xMax; + y = info->yMax; + } else if(nup_pos%nup == 1) { + pdf_page_rendersection(page, swf, x, 0, info->xMin+x, info->yMin, info->xMax+x, info->yMax); + } else if(nup_pos%nup == 2) { + pdf_page_rendersection(page, swf, 0, y, info->xMin, info->yMin+y, info->xMax, info->yMax+y); + } else if(nup_pos%nup == 3) { + pdf_page_rendersection(page, swf, x, y, info->xMin+x, info->yMin+y, info->xMax+x, info->yMax+y); + } + if(nup_pos % nup == nup-1) + swf_output_pagefeed(swf); + + pdf_page_info_destroy(info); + } else { + pdf_page_render(page, swf); + swf_output_pagefeed(swf); + } + pdf_page_destroy(page); } + nup_pos++; } if(!swf_output_save(swf, outputname)) exit(1);