从Itext PDF字节数组转换为多页TIFF文件

时间:2015-01-05 11:19:30

标签: java pdf itext jai ghost4j

我有一个pdf文件(从iText生成的byte[]获得)我需要发送到签名硬件。

由于与java打印机驱动程序有些不兼容,我无法直接发送PDF,因此我需要先将其转换为图像。我已成功将每个PDF页面转换为jpg文件,但客户不喜欢解决方案因为签名不在所有文档中,只在单个页面中。

由于我没有找到任何免费图书馆,我决定分四个步骤:

STEP1 :使用itext生成PDF并保留它。

FileOutputStream fos = new FileOutputStream("tempFile.pdf");
fos.write(myByteArray);
fos.close();
fos.flush();

第2步:从PDF多重转换为List<java.awt.Image>

List<Image> images = null;

Ghostscript.getInstance(); // create gs instance

PDFDocument lDocument = new PDFDocument();
lDocument.load(new File("tempFile.pdf"));

SimpleRenderer renderer = new SimpleRenderer();

renderer.setResolution(300);

try 
{
    images = renderer.render(lDocument);
} 
catch (RendererException | DocumentException e) 
{
    e.printStackTrace();
}

第3步:现在我迭代List<java.awt.Image>转换为单独的TIFF。

    int filename = 1;

    TIFFEncodeParam params = new TIFFEncodeParam();

    Iterator<Image> imageIterator = images.iterator();

    while (imageIterator.hasNext()) {
        BufferedImage  image = (BufferedImage) imageIterator.next();

        FileOutputStream os = new FileOutputStream(/*outputDir + */ filename + ".tif");

        JAI.create("encode", image , os, "TIFF", params);

        filename ++;
    }

第4步:从各种单独的TIFF文件创建多重TIFF

BufferedImage image[] = new BufferedImage[paginas];
    for (int i = 0; i < paginas; i++) {
        SeekableStream ss = new FileSeekableStream((i + 1) + ".tif");
        ImageDecoder decoder = ImageCodec.createImageDecoder("tiff", ss, null);
        PlanarImage pi = new NullOpImage(decoder.decodeAsRenderedImage(0),null,null,OpImage.OP_IO_BOUND);
        image[i] = pi.getAsBufferedImage();
        ss.close();
    }

    TIFFEncodeParam params = new TIFFEncodeParam();
    params.setCompression(TIFFEncodeParam.COMPRESSION_DEFLATE);
    OutputStream out = new FileOutputStream(nombre +".tif");
    ImageEncoder encoder = ImageCodec.createImageEncoder("tiff", out, params);
    List <BufferedImage>list = new ArrayList<BufferedImage>(image.length);

    for (int i = 1; i < image.length; i++) {
        list.add(image[i]);
    }

    params.setExtraImages(list.iterator());
    encoder.encode(image[0]);
    out.close();

    System.out.println("Done.");

DONE。希望对有同样问题的其他人有所帮助。

1 个答案:

答案 0 :(得分:3)

我刚才有同样的问题。我从这里得到了很多帮助: Multiple page tif

所有检查: JAI (Java Advance Image)

以下是将pdf页面转换为png图片的conde片段(使用org.apache.pdfbox库):

    PDDocument document = null;
    document = PDDocument.load(pdf1);

    int pageNum = document.getNumberOfPages();

    PDFImageWriter writer = new PDFImageWriter();
    String filename = pdf1.getPath() + "-";
    filename = filename.replace(".pdf", "");
    writer.writeImage(document, "png", "", 1, Integer.MAX_VALUE, filename);

    document.close();

然后我将每个PNG图像转换为TIFF,然后从多个TIFF图像转换为单个多页TIFF。