summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTor Andersson <tor@ghostscript.com>2005-01-11 06:52:06 +0100
committerTor Andersson <tor@ghostscript.com>2005-01-11 06:52:06 +0100
commit28d9955b1bd82077785b17f101495bc13c3737fc (patch)
tree746f6fb6fe0edd863002166e5fbc9403b4854be7
parentd19e64e90053308a540e76960e0422fa381ae3c9 (diff)
downloadmupdf-28d9955b1bd82077785b17f101495bc13c3737fc.tar.xz
banded ripping in pdfrip
-rw-r--r--test/pdfrip.c123
1 files changed, 76 insertions, 47 deletions
diff --git a/test/pdfrip.c b/test/pdfrip.c
index 0da00d2b..92e3656f 100644
--- a/test/pdfrip.c
+++ b/test/pdfrip.c
@@ -3,10 +3,13 @@
int showtree = 0;
float zoom = 1.0;
+char *namefmt = "out-%02d.ppm";
+fz_renderer *gc;
+int nbands = 1;
void usage()
{
- fprintf(stderr, "usage: pdfrip [-d] [-p password] [-z zoom] file.pdf [pages...]\n");
+ fprintf(stderr, "usage: pdfrip [-d] [-b bands] [-o out-%%02d.ppm] [-p password] [-z zoom] file.pdf pages...\n");
exit(1);
}
@@ -14,13 +17,21 @@ void usage()
* Draw page
*/
-void showpage(pdf_xref *xref, fz_obj *pageobj)
+void showpage(pdf_xref *xref, fz_obj *pageobj, int pagenum)
{
fz_error *error;
pdf_page *page;
-
- fz_debugobj(pageobj);
- printf("\n");
+ char namebuf[256];
+ fz_pixmap *pix;
+ fz_matrix ctm;
+ fz_irect bbox;
+ fz_irect band;
+ FILE *f;
+ int x, y;
+ int w, h;
+ int b;
+
+ sprintf(namebuf, namefmt, pagenum);
error = pdf_loadpage(&page, xref, pageobj);
if (error)
@@ -28,6 +39,9 @@ void showpage(pdf_xref *xref, fz_obj *pageobj)
if (showtree)
{
+ fz_debugobj(pageobj);
+ printf("\n");
+
printf("page\n");
printf(" mediabox [ %g %g %g %g ]\n",
page->mediabox.min.x, page->mediabox.min.y,
@@ -43,37 +57,48 @@ void showpage(pdf_xref *xref, fz_obj *pageobj)
printf("endtree\n");
}
+ ctm = fz_concat(fz_translate(0, -page->mediabox.max.y),
+ fz_scale(zoom, -zoom));
+
+ bbox = fz_roundrect(page->mediabox);
+ bbox.min.x = bbox.min.x * zoom;
+ bbox.min.y = bbox.min.y * zoom;
+ bbox.max.x = bbox.max.x * zoom;
+ bbox.max.y = bbox.max.y * zoom;
+ w = bbox.max.x - bbox.min.x;
+ h = bbox.max.y - bbox.min.y;
+
+ f = fopen(namebuf, "wb");
+ fprintf(f, "P6\n%d %d\n255\n", w, h);
+
+ for (b = 0; b < nbands; b++)
{
- fz_pixmap *pix;
- fz_renderer *gc;
- fz_matrix ctm;
- fz_rect bbox;
-
- error = fz_newrenderer(&gc, pdf_devicergb, 0, 1024 * 512);
- if (error) fz_abort(error);
-
- ctm = fz_concat(fz_translate(0, -page->mediabox.max.y), fz_scale(zoom, -zoom));
-printf("ctm %g %g %g %g %g %g\n",
- ctm.a, ctm.b, ctm.c, ctm.d, ctm.e, ctm.f);
-
-printf("bounding!\n");
- bbox = fz_boundtree(page->tree, ctm);
-printf(" [%g %g %g %g]\n", bbox.min.x, bbox.min.y, bbox.max.x, bbox.max.y);
-printf("rendering!\n");
- bbox = page->mediabox;
- bbox.min.x = bbox.min.x * zoom;
- bbox.min.y = bbox.min.y * zoom;
- bbox.max.x = bbox.max.x * zoom;
- bbox.max.y = bbox.max.y * zoom;
- error = fz_rendertree(&pix, gc, page->tree, ctm, fz_roundrect(bbox), 1);
- if (error) fz_abort(error);
-printf("done!\n");
-
- fz_debugpixmap(pix);
- fz_droppixmap(pix);
+ printf("band %d / %d\n", b, nbands);
+
+ band.min.x = bbox.min.x;
+ band.max.x = bbox.max.x;
+ band.min.y = bbox.min.y + (h * b) / nbands;
+ band.max.y = bbox.min.y + (h * (b + 1)) / nbands;
+
+ error = fz_rendertree(&pix, gc, page->tree, ctm, band, 1);
+ if (error)
+ fz_abort(error);
+
+ for (y = 0; y < pix->h; y++)
+ {
+ for (x = 0; x < pix->w; x++)
+ {
+ putc(pix->samples[y * pix->w * 4 + x * 4 + 1], f);
+ putc(pix->samples[y * pix->w * 4 + x * 4 + 2], f);
+ putc(pix->samples[y * pix->w * 4 + x * 4 + 3], f);
+ }
+ }
- fz_droprenderer(gc);
+ fz_droppixmap(pix);
}
+
+ fclose(f);
+
}
int main(int argc, char **argv)
@@ -82,7 +107,7 @@ int main(int argc, char **argv)
char *filename;
pdf_xref *xref;
pdf_pagetree *pages;
- pdf_outline *outlines;
+ pdf_outlinetree *outlines;
int c;
char *password = "";
@@ -90,13 +115,15 @@ int main(int argc, char **argv)
fz_cpudetect();
fz_accelerate();
- while ((c = getopt(argc, argv, "dz:p:")) != -1)
+ while ((c = getopt(argc, argv, "dz:p:o:b:")) != -1)
{
switch (c)
{
case 'p': password = optarg; break;
case 'z': zoom = atof(optarg); break;
case 'd': ++showtree; break;
+ case 'o': namefmt = optarg; break;
+ case 'b': nbands = atoi(optarg); break;
default: usage();
}
}
@@ -105,31 +132,29 @@ int main(int argc, char **argv)
usage();
filename = argv[optind++];
-
+
error = pdf_newxref(&xref);
if (error)
fz_abort(error);
- error = pdf_loadxref(xref, filename);
+ error = pdf_openpdf(&xref, filename);
if (error)
fz_abort(error);
- error = pdf_decryptxref(xref);
+ error = pdf_decryptpdf(xref);
if (error)
fz_abort(error);
if (xref->crypt)
{
error = pdf_setpassword(xref->crypt, password);
- if (error) fz_abort(error);
+ if (error)
+ fz_abort(error);
}
error = pdf_loadpagetree(&pages, xref);
- if (error) fz_abort(error);
-
- outlines = nil;
-/* error = pdf_loadoutlinetree(&outlines, xref); */
-/* if (error) { fz_warn(error->msg); fz_droperror(error); } */
+ if (error)
+ fz_abort(error);
if (optind == argc)
{
@@ -140,21 +165,25 @@ int main(int argc, char **argv)
if (outlines)
{
printf("outlines\n");
- pdf_debugoutline(outlines, 0);
+ pdf_debugoutlinetree(outlines);
printf("\n");
}
}
+ error = fz_newrenderer(&gc, pdf_devicergb, 0, 1024 * 512);
+ if (error)
+ fz_abort(error);
+
for ( ; optind < argc; optind++)
{
int page = atoi(argv[optind]);
if (page < 1 || page > pdf_getpagecount(pages))
fprintf(stderr, "page out of bounds: %d\n", page);
printf("page %d\n", page);
- showpage(xref, pdf_getpageobject(pages, page - 1));
+ showpage(xref, pdf_getpageobject(pages, page - 1), page);
}
- pdf_closexref(xref);
+ pdf_closepdf(xref);
return 0;
}