Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/332.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
将PDF页面导出到Java中的一系列图像_Java_Image_Pdf_Export - Fatal编程技术网

将PDF页面导出到Java中的一系列图像

将PDF页面导出到Java中的一系列图像,java,image,pdf,export,Java,Image,Pdf,Export,我需要将任意PDF文档的页面导出为jpeg/png/etc格式的一系列单独图像。我需要用Java来做这件事 虽然我确实知道iText、PDFBox和其他各种java pdf库,但我希望能找到一个指向一些工作示例的指针,或者一些操作指南 谢谢。这里有一种方法,将来自web的一些代码片段结合起来 如何将PDF绘制到图像中 从图像创建缓冲图像 原件: 更新: 将生成的图形保存到PNG或JPEG文件 原件: 更新: 组合在一起,可以像这样将所有页面转换为图像: import com.sun.pdfvie

我需要将任意PDF文档的页面导出为jpeg/png/etc格式的一系列单独图像。我需要用Java来做这件事

虽然我确实知道iText、PDFBox和其他各种java pdf库,但我希望能找到一个指向一些工作示例的指针,或者一些操作指南


谢谢。

这里有一种方法,将来自web的一些代码片段结合起来

如何将PDF绘制到图像中

从图像创建缓冲图像

原件:

更新:

将生成的图形保存到PNG或JPEG文件

原件:

更新:

组合在一起,可以像这样将所有页面转换为图像:

import com.sun.pdfview.PDFFile;
import com.sun.pdfview.PDFPage;

import java.awt.Graphics;
import java.awt.GraphicsConfiguration;
import java.awt.GraphicsDevice;
import java.awt.GraphicsEnvironment;
import java.awt.HeadlessException;
import java.awt.Image;
import java.awt.Rectangle;
import java.awt.Transparency;
import java.io.*;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
import javax.swing.*;
import javax.imageio.*;
import java.awt.image.*;

public class ImageMain {
    public static void setup() throws IOException {
        // load a pdf from a byte buffer
        File file = new File("test.pdf");
        RandomAccessFile raf = new RandomAccessFile(file, "r");
        FileChannel channel = raf.getChannel();
        ByteBuffer buf = channel.map(FileChannel.MapMode.READ_ONLY, 0, channel.size());
        PDFFile pdffile = new PDFFile(buf);
        int numPgs = pdffile.getNumPages();
        for (int i = 0; i < numPgs; i++) {
            // draw the first page to an image
            PDFPage page = pdffile.getPage(i);
            // get the width and height for the doc at the default zoom
            Rectangle rect = new Rectangle(0, 0, (int) page.getBBox().getWidth(), (int) page.getBBox().getHeight());
            // generate the image
            Image img = page.getImage(rect.width, rect.height, // width & height
                    rect, // clip rect
                    null, // null for the ImageObserver
                    true, // fill background with white
                    true // block until drawing is done
                    );
            // save it as a file
            BufferedImage bImg = toBufferedImage(img);
            File yourImageFile = new File("page_" + i + ".png");
            ImageIO.write(bImg, "png", yourImageFile);
        }
    }

    // This method returns a buffered image with the contents of an image
    public static BufferedImage toBufferedImage(Image image) {
        if (image instanceof BufferedImage) {
            return (BufferedImage) image;
        }
        // This code ensures that all the pixels in the image are loaded
        image = new ImageIcon(image).getImage();
        // Determine if the image has transparent pixels; for this method's
        // implementation, see e661 Determining If an Image Has Transparent
        // Pixels
        boolean hasAlpha = hasAlpha(image);
        // Create a buffered image with a format that's compatible with the
        // screen
        BufferedImage bimage = null;
        GraphicsEnvironment ge = GraphicsEnvironment.getLocalGraphicsEnvironment();
        try {
            // Determine the type of transparency of the new buffered image
            int transparency = Transparency.OPAQUE;
            if (hasAlpha) {
                transparency = Transparency.BITMASK;
            }
            // Create the buffered image
            GraphicsDevice gs = ge.getDefaultScreenDevice();
            GraphicsConfiguration gc = gs.getDefaultConfiguration();
            bimage = gc.createCompatibleImage(image.getWidth(null), image.getHeight(null), transparency);
        } catch (HeadlessException e) {
            // The system does not have a screen
        }
        if (bimage == null) {
            // Create a buffered image using the default color model
            int type = BufferedImage.TYPE_INT_RGB;
            if (hasAlpha) {
                type = BufferedImage.TYPE_INT_ARGB;
            }
            bimage = new BufferedImage(image.getWidth(null), image.getHeight(null), type);
        }
        // Copy image to buffered image
        Graphics g = bimage.createGraphics();
        // Paint the image onto the buffered image
        g.drawImage(image, 0, 0, null);
        g.dispose();
        return bimage;
    }

    public static boolean hasAlpha(Image image) {
        // If buffered image, the color model is readily available
        if (image instanceof BufferedImage) {
            BufferedImage bimage = (BufferedImage) image;
            return bimage.getColorModel().hasAlpha();
        }
        // Use a pixel grabber to retrieve the image's color model;
        // grabbing a single pixel is usually sufficient
        PixelGrabber pg = new PixelGrabber(image, 0, 0, 1, 1, false);
        try {
            pg.grabPixels();
        } catch (InterruptedException e) {
        }
        // Get the image's color model
        ColorModel cm = pg.getColorModel();
        return cm.hasAlpha();
    }

    public static void main(final String[] args) {
        SwingUtilities.invokeLater(new Runnable() {
            public void run() {
                try {
                    ImageMain.setup();
                } catch (IOException ex) {
                    ex.printStackTrace();
                }
            }
        });
    }
}

如果你考虑了JPLAND PDF库,它是内置的,在E/P>>P>中有EOSURN源文件,只需从1开始,而不是从0开始for循环。您的问题将得到解决。

如果您发现sun渲染器不适用于所有PDF文档,您可以考虑使用JPDFImage

为了提高效率,您应该将每个PDF页面转换为缓冲图像,然后再转换为所需的各种图像格式。这样可以避免将每种格式的图像从PDF转换为图像

以下是使用jPDFImages从PDF转换为缓冲图像的链接:

对于每个页面图像,您可以简单地导出为不同的图像格式: ImageIO.WritePageBuffereImage、JPEG、outputFile; ImageIO.WritePageBuffereImage,PNG,outputFile;
等等。

有不同的库可以做这件事。我是通过努力做到这一点的。但在我看来,最有效的解决办法是使用。但是,如果你认为你需要一个简单的解决方案,使用。但是ImageMagick在内部调用了幽灵脚本。使用ghostscript或imagemagick可以为您提供更好的解决方案。它比任何其他库都快得多。

PDF以位图形式显示与Android兼容的代码

File pdfFile = new File(filePath);
PdfRenderer renderer = new PdfRenderer(ParcelFileDescriptor.open(pdfFile, ParcelFileDescriptor.MODE_READ_ONLY));

final int pageCount = renderer.getPageCount();
//Currently for a page, iterate for all the pages
PdfRenderer.Page page = renderer.openPage(pageCount);
int width =  page.getWidth();
int height = page.getHeight();

Bitmap bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);

丢失的hasAlpha方法可以在这里找到@jedierikb我编辑了pdf渲染器的链接,因为它不再工作,但我找不到包含示例的页面。也许你知道它移动到了哪里。exampledepot的链接都不起作用。您是否有任何关于示例使用的库的参考资料,或任何其他可能有帮助的信息?