java如何将pdf转换成image

网友投稿 228 2023-08-06

java如何将pdf转换成image

本文实例为大家分享了java将pdf转换image的具体代码,供大家参考,具体内容如下

首先使用了使用了apache的PDFBox组件1.8.4版本

package pdf;

import java.awt.image.BufferedImage;

import java.io.File;

import java.io.IOException;

import java.util.Date;

import java.util.List;

import javax.imageio.ImageIO;

import org.apache.pdfbox.pdmodel.PDDocument;

import org.apache.pdfbox.pdmodel.PDPage;

public class PDFBox {

@SuppressWarnings("rawtypes")

public static void main(String[] args) throws IOException {

String p=System.getProperty("user.dir") + "/"+"zk.pdf";

PDDocument doc = PDDocument.load(p);

int pageCount = doc.getNumberOfPages();

System.out.println(pageCount);

Date start = new Date();

try {

List pages = doc.getDocumentCatalog().getAllPages();

for(int i=0;i

PDPage page = (PDPage) pages.get(i);

@SuppressWarnings("unused")

int width = wbGkpMnew Float(page.getTrimBox().getWidth()).intValue();

@SuppressWarnings("unused")

int height = new Float(page.getTrimBox().getHeight()).intValue();

BufferedImage image = page.convertToImage();

ImageIO.write(image, "jpg", new File("img" + File.separator + (i + 1) + ".jpg"));

System.out.println("image in the page -->"+(i+1));

}

} catch (Exception e) {

e.printStackTrace();

}finally{

if(doc != null){

doc.close();

}

}

Date end = new Date();

System.out.println(end.getTime()-start.getTime());

System.out.println("over");

}

}

但是其问题在于问题:

当PDF文档为180M大小时直接报解析异常

当PDF页数为500多页时处理非常慢

其后尝试使用了pdf-renderer 1.0.5 版本

package pdf;

import java.awt.Image;

import java.awt.Rectangle;

import java.awt.image.BufferedImage;

import java.io.File;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.RandomAccessFile;

import java.nio.MappedByteBuffer;

import java.nio.channels.FileChannel;

import com.sun.image.codec.jpeg.JPEGCodec;

import com.sun.image.codec.jpeg.JPEGEncodeParam;

import com.sun.image.codec.jpeg.JPEhttp://GImageEncoder;

import com.sun.pdfview.PDFFile;

import com.sun.pdfview.PDFPage;

public class PDFRenderer {

public static void main(String[] args) throws IOException{

String pdfRealePath=System.getProperty("user.dir") + "/"+"zk.pdf";

File file = new File(pdfRealePath);

RandomAccessFile raf = new RandomAccessFile(file, "r");

FileChannel channel = raf.getChannel();

MappedByteBuffer buf = channel.map(FileChannel.MapMode.READ_ONLY,

0, channel.size());

PDFFile pdffile = new PDFFile(buf);

for (int i = 1; i <= pdffile.getNumPages(); i++) {

PDFPage page = pdffile.getPage(i);

Rectangle rect = new Rectangle(0, 0, ((int) page.getBBox()

.getWidth()), ((int) page.getBBox().getHeight()));

Image img = page.getImage(rect.width, rect.height, rect, null,true,true);

BufferedImage tag = new BufferedImage(rect.width, rect.height,

BufferedImage.TYPE_INT_RGB);

tag.getGraphics().drawImage(img, 0, 0, rect.width, rect.height,null);

FileOutputStream out = new FileOutputStream("img" + File.separator + (i + 1) + ".jpg"); // 输出到文件流

JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out);

JPEGEncodeParam param2 = encoder.getDefaultJPEGEncodeParam(tag);

param2.setQuality(1f, false);// 1f是提高生成的图片质量

encoder.setJPEGEncodeParam(param2);

encoder.encode(tag); // JPEG编码

out.close();

System.out.println("image in the page -->"+(i+1));

}

}

}

但是其问题在于问题: 当pdf的版本不为1.4时,直接报错:Expected 'xref' at start of table

pdfbox与pdfrenderer相比较来说,转换的效率要低得多。200页左右的pdf花费的时间是后者的6倍左右。同时,对于中文字体的支持存在些问题。

但是对于却不存在pdf版本不同无法转换的问题。

pdfrenderer 不能转换1.4以上版本,查找了解决办法但是没有找到。

PDPage page = (PDPage) pages.get(i);

@SuppressWarnings("unused")

int width = wbGkpMnew Float(page.getTrimBox().getWidth()).intValue();

@SuppressWarnings("unused")

int height = new Float(page.getTrimBox().getHeight()).intValue();

BufferedImage image = page.convertToImage();

ImageIO.write(image, "jpg", new File("img" + File.separator + (i + 1) + ".jpg"));

System.out.println("image in the page -->"+(i+1));

}

} catch (Exception e) {

e.printStackTrace();

}finally{

if(doc != null){

doc.close();

}

}

Date end = new Date();

System.out.println(end.getTime()-start.getTime());

System.out.println("over");

}

}

但是其问题在于问题:

当PDF文档为180M大小时直接报解析异常

当PDF页数为500多页时处理非常慢

其后尝试使用了pdf-renderer 1.0.5 版本

package pdf;

import java.awt.Image;

import java.awt.Rectangle;

import java.awt.image.BufferedImage;

import java.io.File;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.RandomAccessFile;

import java.nio.MappedByteBuffer;

import java.nio.channels.FileChannel;

import com.sun.image.codec.jpeg.JPEGCodec;

import com.sun.image.codec.jpeg.JPEGEncodeParam;

import com.sun.image.codec.jpeg.JPEhttp://GImageEncoder;

import com.sun.pdfview.PDFFile;

import com.sun.pdfview.PDFPage;

public class PDFRenderer {

public static void main(String[] args) throws IOException{

String pdfRealePath=System.getProperty("user.dir") + "/"+"zk.pdf";

File file = new File(pdfRealePath);

RandomAccessFile raf = new RandomAccessFile(file, "r");

FileChannel channel = raf.getChannel();

MappedByteBuffer buf = channel.map(FileChannel.MapMode.READ_ONLY,

0, channel.size());

PDFFile pdffile = new PDFFile(buf);

for (int i = 1; i <= pdffile.getNumPages(); i++) {

PDFPage page = pdffile.getPage(i);

Rectangle rect = new Rectangle(0, 0, ((int) page.getBBox()

.getWidth()), ((int) page.getBBox().getHeight()));

Image img = page.getImage(rect.width, rect.height, rect, null,true,true);

BufferedImage tag = new BufferedImage(rect.width, rect.height,

BufferedImage.TYPE_INT_RGB);

tag.getGraphics().drawImage(img, 0, 0, rect.width, rect.height,null);

FileOutputStream out = new FileOutputStream("img" + File.separator + (i + 1) + ".jpg"); // 输出到文件流

JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out);

JPEGEncodeParam param2 = encoder.getDefaultJPEGEncodeParam(tag);

param2.setQuality(1f, false);// 1f是提高生成的图片质量

encoder.setJPEGEncodeParam(param2);

encoder.encode(tag); // JPEG编码

out.close();

System.out.println("image in the page -->"+(i+1));

}

}

}

但是其问题在于问题: 当pdf的版本不为1.4时,直接报错:Expected 'xref' at start of table

pdfbox与pdfrenderer相比较来说,转换的效率要低得多。200页左右的pdf花费的时间是后者的6倍左右。同时,对于中文字体的支持存在些问题。

但是对于却不存在pdf版本不同无法转换的问题。

pdfrenderer 不能转换1.4以上版本,查找了解决办法但是没有找到。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Vue表单类的父子组件数据传递示例
下一篇:Vue利用canvas实现移动端手写板的方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~