将PDF页面导出到Java中的一系列图像
我需要将任意PDF文档的页面导出为jpeg/png/etc格式的一系列单独图像。我需要用Java来做这件事 虽然我确实知道iText、PDFBox和其他各种java pdf库,但我希望能找到一个指向一些工作示例的指针,或者一些操作指南将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
谢谢。这里有一种方法,将来自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的链接都不起作用。您是否有任何关于示例使用的库的参考资料,或任何其他可能有帮助的信息?