PDF文档是我们日常办公中使用最频繁的文档格式 。但因为大多数PDF文档都包含很多页面图像或大量图片 ,这就导致PDF文档过大 ,处理起来较为麻烦 。PDF文件过大 ,就会导致传输或者下载的速度变慢 ,也会增加传输失败的风险 ,影响办公效率。因此我们需要对PDF文档进行压缩 。本文将从以下两方面介绍如何通过Java应用程序压缩PDF文档 。
在使用PDF文件过程中 ,经常会出现由于体积过大导致文件传输失败的情况 。遇到这种情况 ,我们可以先将PDF文件压缩一下再进行传输 。而除了压缩文档内容以外 ,压缩图片是缩小PDF文档的主要方法之一 。本文将分为2部分分别介绍如何通过Java代码压缩PDF文档 。希望这篇文章能对大家有所帮助 。
压缩PDF文档中的内容及图片
压缩PDF文档中的高分辨率图片
1.引入jar包
导入方法1:
手动引入 。将Free Spire.PDF for Java下载到本地 ,解压,找到lib文件夹下的Spire.PDF.jar文件 。在IDEA中打开如下界面 ,将本地路径中的jar文件引入Java程序:
导入方法2:如果您想通过 Maven安装 ,则可以在 pom.xml 文件中添加以下代码导入 JAR 文件。
压缩PDF文档中的内容及图片
压缩PDF文档中的内容及图片的详细步骤如下:
创建 PdfDocument 类的对象 。
使用 PdfDocument.loadFromFile() 方法加载 PDF 文档 。
使用 PdfDocument.getFileInfo().setIncrementalUpdate() 方法将增量更新设置为false。
使用 PdfDocument.setCompressionLevel() 方法将压缩级别设置为最佳,以压缩文档中的内容 。 您可以从 PdfCompressionLevel 枚举中选择其他一些级别 。
循环遍历文档中的页面 ,使用 PdfPageBase.getImagesInfo() 方法获取每个页面的图像信息集合。
遍历集合中的所有项目 ,并使用 PdfBitmap.setQuality() 方法压缩特定图像的质量 。
使用 PdfPageBase.replaceImage() 方法将原始图像替换为压缩图像 。使用 PdfDocument.saveToFile() 方法将文档保存到另一个 PDF 文件 。
完整代码
Java
import com.spire.pdf.PdfCompressionLevel;
import com.spire.pdf.PdfDocument;
import com.spire.pdf.PdfPageBase;
import com.spire.pdf.exporting.PdfImageInfo;
import com.spire.pdf.graphics.PdfBitmap;
public class CompressPDFImage {
public static void main(String[] args) {
//创建 PdfDocument 类的对象 。
PdfDocument doc = new PdfDocument();
//加载 PDF 文档
doc.loadFromFile("测试文档.pdf");
//将增量更新设置为false
doc.getFileInfo().setIncrementalUpdate(false);
//将压缩级别设置为最佳
doc.setCompressionLevel(PdfCompressionLevel.Best);
//循环遍历文档中的页面
for (int i = 0; i < doc.getPages().getCount(); i++) {
//获取特定页面
PdfPageBase page = doc.getPages().get(i);
//获取每个页面的图像信息集合
PdfImageInfo[] images = page.getImagesInfo();
//遍历集合中的项目
if (images != null && images.length > 0)
for (int j = 0; j < images.length; j++) {
//获取指定图像
PdfImageInfo image = images[j];
PdfBitmap bp = new PdfBitmap(image.getImage());
//设置压缩质量
bp.setQuality(20);
//用压缩后的图片替换原始图片
page.replaceImage(j, bp);
}
//保存文件
doc.saveToFile("压缩PDF文档.pdf");
doc.close();
}
}
}
效果对比图
压缩 PDF 文档中的高分辨率图像
本方法仅对文档中的高分辨率图像进行无损压缩,而低分辨率的图像将不再被压缩 。
创建 PdfDocument 类的对象 。
使用 PdfDocument.loadFromFile() 方法加载 PDF 文档 。
使用 PdfDocument.getFileInfo().setIncrementalUpdate() 方法将 IncrementalUpdate 设置为 false 。
声明一个 PdfPageBase 变量 。
循环遍历页面并使用 PdfDocument.getPages().get() 方法获取特定页面。
循环遍历页面中的图像 。并使用 page.tryCompressImage(info.Index) 方法压缩高分辨率图像 。
使用 PdfDocument.saveToFile() 方法将文档保存到另一个 PDF 文件。
完整代码
Java
import com.spire.pdf.PdfDocument;
import com.spire.pdf.PdfPageBase;
import com.spire.pdf.exporting.PdfImageInfo;
public class CompressPDFImage {
public static void main(String[] args) {
//创建 PdfDocument 类的对象
PdfDocument doc = new PdfDocument
//加载 PDF 文档
doc.loadFromFile("示例文档.pdf");
//将IncrementalUpdate设置为false
doc.getFileInfo().setIncrementalUpdate(false);
//声明一个 PdfPageBase 变量
PdfPageBase page;
//循环遍历页面
for (int i = 0; i < doc.getPages().getCount(); i++) {
//获取指定页面
page = doc.getPages().get(i);
if (page != null) {
if(page.getImagesInfo() != null){
//循环遍历页面中的图像
for (PdfImageInfo info: page.getImagesInfo()) {
//使用tryCompressImage方法压缩高分辨率图像
page.tryCompressImage(info.getIndex());
}
}
}
}
//保存文件
doc.saveToFile("输出结果.pdf");
}
}
效果对比图
—本文完—
声明:本站所有文章 ,如无特殊说明或标注 ,均为本站原创发布 。任何个人或组织 ,在未征得本站同意时 ,禁止复制 、盗用 、采集、发布本站内容到任何网站 、书籍等各类媒体平台 。如若本站内容侵犯了原著者的合法权益 ,可联系我们进行处理。