当前位置: 首页 > news >正文

使用PDFBox调整PDF每页格式

目录

一、内容没有图片

二、内容有图片


maven依赖,这里使用的是pdfbox的2.0.30版本

        <dependency><groupId>org.apache.pdfbox</groupId><artifactId>pdfbox</artifactId><version>2.0.30</version></dependency><dependency><groupId>org.apache.pdfbox</groupId><artifactId>pdfbox-tools</artifactId><version>2.0.30</version></dependency>

一、内容没有图片

如果内容没有图片,可以直接将纸张改为A4大小

import java.io.File;
import java.io.IOException;
import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.pdmodel.PDPage;
import org.apache.pdfbox.pdmodel.common.PDRectangle;public class AdjustPdfPageWidthToA4 {public static void main(String[] args) {// 输入的PDF文件路径String inputFilePath = "input.pdf";// 输出的PDF文件路径String outputFilePath = "output.pdf";try {// 加载PDF文件PDDocument document = PDDocument.load(new File(inputFilePath));// 遍历每一页for (PDPage page : document.getPages()) {// 将页面宽度调整为A4尺寸page.setMediaBox(PDRectangle.A4);}// 保存修改后的PDF文件document.save(outputFilePath);document.close();System.out.println("PDF页面宽度已调整为A4尺寸,并保存为新的PDF文件。");} catch (IOException e) {e.printStackTrace();}}
}

但是如果有图片的话,会出现图片被截断,显示不全的情况出现,所以我们需要对图片元素按比例缩放

二、内容有图片

首先要对页面内容进行判断,如果页面是图片的话,对图片进行比例缩放,比如A4,就缩放到可以放进A4

import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;import org.apache.pdfbox.cos.COSName;
import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.pdmodel.PDPage;
import org.apache.pdfbox.pdmodel.PDPageContentStream;
import org.apache.pdfbox.pdmodel.PDResources;
import org.apache.pdfbox.pdmodel.common.PDRectangle;
import org.apache.pdfbox.pdmodel.graphics.PDXObject;
import org.apache.pdfbox.pdmodel.graphics.image.PDImageXObject;
import org.apache.pdfbox.text.PDFTextStripper;import javax.imageio.ImageIO;/*** @author zjy* @describe 调整PDF每页为A4格式*/
public class AdjustPdfPageWidthToA4Util {static String inputFilePath = "C:\\xxx\\xxx\\xx.pdf";// 输出的PDF文件路径static String outputFilePath = "D:\\result.pdf";public static void main(String[] args) {try {// 加载PDF文件PDDocument document = PDDocument.load(new File(inputFilePath));// 遍历每一页int totalPages = document.getNumberOfPages();for (int i = 0; i < totalPages; i++) {// 获取当前Page页面PDPage page = document.getPage(i);// 获取对应页面的资源对象PDResources resources = page.getResources();// 遍历当前页面所有内容,找出图片对象for (COSName cosName : resources.getXObjectNames()) {PDXObject pdxObject = resources.getXObject(cosName);// 判断是不是图片对象if (pdxObject instanceof PDImageXObject) {// 获取图片对象PDImageXObject pdxObject1 = (PDImageXObject) pdxObject;BufferedImage image = pdxObject1.getImage();// 4、创建页面内容流,指定操作哪个文档中的哪个页面PDPageContentStream stream = new PDPageContentStream(document, page);float[] imageWH = getImageWH(image, PDRectangle.A4);stream.drawImage(pdxObject1, imageWH[0], imageWH[1], imageWH[2], imageWH[3]); // 绘制图片到PDF页面里面stream.close(); // 关闭页面内容流page.setMediaBox(PDRectangle.A4);} else {page.setMediaBox(PDRectangle.A4);}}}// 保存修改后的PDF文件document.save(outputFilePath);document.close();System.out.println("PDF页面宽度已调整为A4尺寸,并保存为新的PDF文件。");} catch (IOException e) {e.printStackTrace();}}/*** 获取图片的宽度、高度,单位是【pt】** @param box PDF文档页面矩形区域对象,可以获取到矩形区域的宽高* @return 返回缩放之后的图片宽高*/public static float[] getImageWH(BufferedImage img, PDRectangle box) {try {// px 转换成 pt 单位float xAxis;float yAxis;int w = img.getWidth();int h = img.getHeight();float width = (float) (w * 3.0 / 4); // 这里是因为 1pt = 3/4 px,pt和px单位转换float height = (float) (h * 3.0 / 4);float pw = box.getWidth() - 60; // 设置图片与文档边缘的空白间距float ph = box.getHeight() - 60; // 设置图片与文档边缘的空白间距if (width > pw) {float scale = pw / width;  // 缩放比列width = pw; // 宽度等于页面宽度height = height * scale; // 高度自动缩放} else {float scale = ph / height;  // 缩放比列height = ph; // 高度等于页面高度width = width * scale;  // 宽度自动缩放}// 计算图片在X、Y轴上的显示位置xAxis = (box.getWidth() - width) / 2; // X轴居中对齐
//            yAxis = box.getHeight() - height - 10; // 距离页面顶部10个ptyAxis = (box.getHeight() - height) / 2; // Y轴垂直居中对齐return new float[]{xAxis, yAxis, width, height};} catch (Exception e) {e.printStackTrace();}return new float[]{0, 0, 0, 0};}
}

运行完如下图所示,图片缩小至能放入A4,放在正中间

三、改进

上面的代码是将图片等比例缩小到A4能够放得下,也就是上下或者左右可能有很大的空白,图片比较小,难以看清,因此改进

import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;import org.apache.pdfbox.cos.COSName;
import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.pdmodel.PDPage;
import org.apache.pdfbox.pdmodel.PDPageContentStream;
import org.apache.pdfbox.pdmodel.PDResources;
import org.apache.pdfbox.pdmodel.common.PDRectangle;
import org.apache.pdfbox.pdmodel.graphics.PDXObject;
import org.apache.pdfbox.pdmodel.graphics.image.PDImageXObject;
import org.apache.pdfbox.text.PDFTextStripper;import javax.imageio.ImageIO;/*** @author zjy* @describe 调整PDF每页为A4格式*/
public class AdjustPdfPageWidthToA4Util {static String inputFilePath = "C:\\xxx\\xxx\\xx.pdf";// 输出的PDF文件路径static String outputFilePath = "D:\\result.pdf";public static void main(String[] args) {try {// 加载PDF文件PDDocument document = PDDocument.load(new File(inputFilePath));// 遍历每一页int totalPages = document.getNumberOfPages();for (int i = 0; i < totalPages; i++) {// 获取当前Page页面PDPage page = document.getPage(i);// 获取对应页面的资源对象PDResources resources = page.getResources();// 遍历当前页面所有内容,找出图片对象for (COSName cosName : resources.getXObjectNames()) {PDXObject pdxObject = resources.getXObject(cosName);// 判断是不是图片对象if (pdxObject instanceof PDImageXObject) {// 获取图片对象PDImageXObject pdxObject1 = (PDImageXObject) pdxObject;BufferedImage image = pdxObject1.getImage();// 4、创建页面内容流,指定操作哪个文档中的哪个页面PDPageContentStream stream = new PDPageContentStream(document, page);float[] imageWH = getImageWH(image, PDRectangle.A4);stream.drawImage(pdxObject1, 0, 0, imageWH[0], imageWH[1]); // 绘制图片到PDF页面里面stream.close(); // 关闭页面内容流
//                        page.setMediaBox(PDRectangle.A4);page.setMediaBox(new PDRectangle(imageWH[0], imageWH[1]));} else {page.setMediaBox(PDRectangle.A4);}}}// 保存修改后的PDF文件document.save(outputFilePath);document.close();System.out.println("PDF页面宽度已调整为A4尺寸,并保存为新的PDF文件。");} catch (IOException e) {e.printStackTrace();}}/*** 获取图片的宽度、高度,单位是【pt】** @param box PDF文档页面矩形区域对象,可以获取到矩形区域的宽高* @return 返回缩放之后的图片宽高*/public static float[] getImageWH(BufferedImage img, PDRectangle box) {try {// px 转换成 pt 单位float xAxis;float yAxis;int w = img.getWidth();int h = img.getHeight();float width = (float) (w * 3.0 / 4); // 这里是因为 1pt = 3/4 px,pt和px单位转换float height = (float) (h * 3.0 / 4);float pw = box.getWidth() ;float ph = box.getHeight() ;if (width > pw) {float scale = pw / width;  // 缩放比列width = pw; // 宽度等于页面宽度height = height * scale; // 高度自动缩放} else {float scale = ph / height;  // 缩放比列height = ph; // 高度等于页面高度width = width * scale;  // 宽度自动缩放}// 计算图片在X、Y轴上的显示位置return new float[]{width, height};} catch (Exception e) {e.printStackTrace();}return new float[]{0, 0};}
}

这样子图片的宽度是A4的,长度就是原图片的长度了

以上内容参考以下博客【PDFBox】PDFBox操作PDF文档之添加本地图片、添加网络图片、图片宽高自适应、图片水平垂直居中对齐-支持Android_pdfbox缩放比例-CSDN博客文章浏览阅读322次,点赞2次,收藏3次。PDImageXObject类中提个了一些静态方法createFromFile(imagePath,doc)方法:采用File文件的方式读取本地磁盘中的图片。imagePath参数:图片的路径。doc参数:PDF文档对象。getImage()方法:返回BufferedImage图片对象。getSuffix()方法:返回图片的后缀类型,例如:jpg、png等。_pdfbox缩放比例https://blog.csdn.net/qq_27489007/article/details/134451128

http://www.lryc.cn/news/323591.html

相关文章:

  • 【3D reconstruction 学习笔记】
  • (附源码)基于Spring Boot与Vue的宠物用品销售系统设计与实现
  • Qwen及Qwen-audio大模型微调项目汇总
  • 浅析ArcGis中的软件——ArcMap、ArcScene、 ArcGlobe、ArcCatalog
  • AndroidStudio插件出现“Compatible with IntelliJ IDEA only“错误时的解决方案
  • 探索未来的编程趋势与挑战
  • 第十二届蓝桥杯省赛CC++ 研究生组
  • Ubuntu自启GUI程序
  • 【光标精灵】让您享受鼠标皮肤多样化快捷更换
  • Vue 常见面试题(一)
  • Elasticsearch 的 scroll API
  • Leedcode刷题——2 字符串
  • 2016年认证杯SPSSPRO杯数学建模B题(第二阶段)多帧图像的复原与融合全过程文档及程序
  • WMI接口设计实现
  • 前端项目,个人笔记(二)【Vue-cli - 引入阿里矢量库图标 + 吸顶交互 + setup语法糖】
  • OpenCV 介绍使用
  • Python 10个面试题实例
  • Python:熟悉简单的skfuzzy构建接近生活事件的模糊控制器”(附带详细注释说明)+ 测试结果
  • opencv函数使用查找
  • 使用 pypdf 快速切分 PDF 文件
  • Avalonia(11.0.2)+.NET6 打包运行到银河麒麟V10桌面系统
  • Mac nvm install failed python: not found
  • C语言基础知识复习(考研)
  • Prometheus Grafana 配置仪表板
  • docker 哲学 - 网络桥接器、容器网络接口 、容器间的通信方式
  • Python 将HTML转为PDF、图片、XML、XPS格式
  • 排序算法记录(冒泡+快排+归并)
  • 简单聊聊如何更优雅地初始化对象:构造函数、Builder模式和静态工厂方法比较
  • 跳过mysql权限验证来修改密码-GPT纯享版
  • Vue3快速上手(十七)Vue3之状态管理Pinia