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

合作网站开发公司视频教学网站cms

合作网站开发公司,视频教学网站cms,网站统计关键词,蚌埠网站建设专业公司哪家好这篇文章#xff0c;主要介绍使用itext7将多个PDF文件、图片合并成一个PDF文件#xff0c;图片旋转、图片缩放。 目录 一、itext7合并PDF 1.1、引入依赖 1.2、合并PDF介绍 1.3、采用字节数组方式读取PDF文件 1.4、合并多个PDF文件 1.5、合并图片到PDF文件 1.6、旋转图… 这篇文章主要介绍使用itext7将多个PDF文件、图片合并成一个PDF文件图片旋转、图片缩放。 目录 一、itext7合并PDF 1.1、引入依赖 1.2、合并PDF介绍 1.3、采用字节数组方式读取PDF文件 1.4、合并多个PDF文件 1.5、合并图片到PDF文件 1.6、旋转图片 1.7、完整案例代码 1PDFUtil工具类 2测试类代码 3合并效果 一、itext7合并PDF 1.1、引入依赖 我这里使用的是itext-core7.1.16版本只需要引入一个itext-core依赖即可因为这个依赖里面已经给我们引入了itext所需要的依赖。 !-- 引入 itext7-core 依赖 -- dependencygroupIdcom.itextpdf/groupIdartifactIditext7-core/artifactIdversion7.1.16/versiontypepom/type /dependency 1.2、合并PDF介绍 最简单的合并方式那就是读取两个PDF文件然后将其合并成一个新的PDF文件保存到服务器上面之后在将这个新的PDF文件和下一个待合并的PDF文件进行合并以此类推最终可以得到一个完整的PDF文件但是这种方式缺点在于每一次合并之后都需要新生成一个PDF文件并且下一次合并之后还要再读取这个PDF文件这就会导致多次读取文件的过程效率不是很理想。 这篇文章我主要是将PDF作为字节数组读取到内存里面然后在内存中合并两个PDF的字节数据这样可以减少读取和生成PDF文件的次数执行效率方面也就会更加好一些了合并两个PDF字节数组的方法如下所示 /*** 基于内存中的字节数组进行PDF文档的合并* param firstPdf 第一个PDF文档* param secondPdf 第二个PDF文档*/ private static byte[] mergePdfBytes(byte[] firstPdf, byte[] secondPdf) throws IOException {if (firstPdf ! null secondPdf ! null) {// 创建字节数组基于内存进行合并ByteArrayOutputStream baos new ByteArrayOutputStream();PdfDocument destDoc new PdfDocument(new PdfWriter(baos));// 合并的pdf文件对象PdfDocument firstDoc new PdfDocument(new PdfReader(new ByteArrayInputStream(firstPdf)));PdfDocument secondDoc new PdfDocument(new PdfReader(new ByteArrayInputStream(secondPdf)));// 合并对象PdfMerger merger new PdfMerger(destDoc);merger.merge(firstDoc, 1, firstDoc.getNumberOfPages());merger.merge(secondDoc, 1, secondDoc.getNumberOfPages());// 关闭文档流merger.close();firstDoc.close();secondDoc.close();destDoc.close();return baos.toByteArray();}return null; } 1.3、采用字节数组方式读取PDF文件 合并PDF文件的时候有些PDF文件可能是网络上的也有些是本地磁盘上的所以这里需要做下判断如果是网络上的PDF文件则需要首先访问网络再将其保存到字节数组里面如果是本地磁盘文件则需要读取本地文件。 /*** 将pdf文档转换成字节数组* param pdf PDF文档路径* return 返回对应PDF文档的字节数组*/ private static byte[] getPdfBytes(String pdf) throws Exception {ByteArrayOutputStream out new ByteArrayOutputStream();InputStream is;if (pdf.startsWith(http://) || pdf.startsWith(https://)) {is new URL(pdf).openStream();} else {is new FileInputStream(pdf);}byte[] data new byte[2048];int len;while ((len is.read(data)) ! -1) {out.write(data, 0, len);}return out.toByteArray(); } 1.4、合并多个PDF文件 合并PDF时候直接传递需要合并的PDF文件路径就可以啦调用下面方法就可以完成合并。 /*** 将给定List集合中的pdf文档按照顺序依次合并生成最终的目标PDF文档* param pdfPathLists 待合并的PDF文档路径集合可以是本地PDF文档也可以是网络上的PDF文档* param destPath 目标合并生成的PDF文档路径*/ public static boolean mergeMultiplePdfs(ListString pdfPathLists, String destPath) {try {int size pdfPathLists.size();byte[] pdfData getPdfBytes(pdfPathLists.get(0));for (int i 1; i size; i) {pdfData mergePdfBytes(pdfData, getPdfBytes(pdfPathLists.get(i)));}if (pdfData ! null) {FileOutputStream fis new FileOutputStream(destPath);fis.write(pdfData);fis.close();}return true;} catch (Exception e) {logger.error(合并PDF异常:, e);}return false; } 1.5、合并图片到PDF文件 如何将图片也一起合并到PDF文件里面呢这里我是将图片直接添加到PDF文件的空白页面中实现的一张图片占据一个页面当然你也可以设置显示在相同页面超过之后页面高度之后图片会自动显示到下一个页面。 /*** 将给定集合中的图片合并到一个pdf文档里面* param imagePathList 图片路径集合* param destPath 合并之后的PDF文档*/ public static boolean mergeImagesToPdf(ListString imagePathList, String destPath) {try {PdfDocument pdfDocument new PdfDocument(new PdfWriter(destPath));Document document new Document(pdfDocument);if (imagePathList ! null imagePathList.size() 0) {int size imagePathList.size();for (int i 0; i size; i) {String imgPath imagePathList.get(i);ImageData imageData;if (imgPath.startsWith(http://) || imgPath.startsWith(https://)) {imageData ImageDataFactory.create(new URL(imgPath));} else {imageData ImageDataFactory.create(imgPath);}Image image new Image(imageData);/*设置旋转的弧度值默认是逆时针旋转的。弧度、角度换算公式1° PI / 180°1 rad 180° / PI*/image.setRotationAngle(- Math.PI / 2); // 顺时针旋转90°// 设置图片自动缩放即图片宽高自适应image.setAutoScale(true);document.add(image);if (i ! size - 1) {// 最后一页不需要新增空白页document.add(new AreaBreak(AreaBreakType.NEXT_PAGE));}}}pdfDocument.close();return true;} catch (Exception e) {logger.error(合并图片到PDF异常:, e);}return false; } 1.6、旋转图片 在某些需求下你可以想某个图片竖向摆放、某些图片横向摆放那么这个时候就可以调用itext7中【Image】图片对象的【setRotationAngle()】方法对其进行旋转需要注意的是setRotationAngle方法设置的旋转弧度而不是旋转角度并且它是逆时针旋转的。弧度和角度之间有一个转换公式如下所示 1.7、完整案例代码 1PDFUtil工具类 package com.gitcode.itext.util;import com.itextpdf.io.image.ImageData; import com.itextpdf.io.image.ImageDataFactory; import com.itextpdf.kernel.pdf.PdfDocument; import com.itextpdf.kernel.pdf.PdfReader; import com.itextpdf.kernel.pdf.PdfWriter; import com.itextpdf.kernel.utils.PdfMerger; import com.itextpdf.layout.Document; import com.itextpdf.layout.element.AreaBreak; import com.itextpdf.layout.element.Image; import com.itextpdf.layout.property.AreaBreakType; import org.slf4j.Logger; import org.slf4j.LoggerFactory;import java.io.*; import java.net.URL; import java.util.List;/*** version 1.0.0* Date: 2023/10/04 10:07* Author ZhuYouBin* Description: PDF工具类【基于 itext7 组件实现】*/ public class PDFUtil {private static final Logger logger LoggerFactory.getLogger(PDFUtil.class);/*** 将给定List集合中的pdf文档按照顺序依次合并生成最终的目标PDF文档* param pdfPathLists 待合并的PDF文档路径集合可以是本地PDF文档也可以是网络上的PDF文档* param destPath 目标合并生成的PDF文档路径*/public static boolean mergeMultiplePdfs(ListString pdfPathLists, String destPath) {try {int size pdfPathLists.size();byte[] pdfData getPdfBytes(pdfPathLists.get(0));for (int i 1; i size; i) {pdfData mergePdfBytes(pdfData, getPdfBytes(pdfPathLists.get(i)));}if (pdfData ! null) {FileOutputStream fis new FileOutputStream(destPath);fis.write(pdfData);fis.close();}return true;} catch (Exception e) {logger.error(合并PDF异常:, e);}return false;}/*** 将给定集合中的图片合并到一个pdf文档里面* param imagePathList 图片路径集合* param destPath 合并之后的PDF文档*/public static boolean mergeImagesToPdf(ListString imagePathList, String destPath) {try {PdfDocument pdfDocument new PdfDocument(new PdfWriter(destPath));Document document new Document(pdfDocument);if (imagePathList ! null imagePathList.size() 0) {int size imagePathList.size();for (int i 0; i size; i) {String imgPath imagePathList.get(i);ImageData imageData;if (imgPath.startsWith(http://) || imgPath.startsWith(https://)) {imageData ImageDataFactory.create(new URL(imgPath));} else {imageData ImageDataFactory.create(imgPath);}Image image new Image(imageData);/*设置旋转的弧度值默认是逆时针旋转的。弧度、角度换算公式1° PI / 180°1 rad 180° / PI*/image.setRotationAngle(- Math.PI / 2); // 顺时针旋转90°// 设置图片自动缩放即图片宽高自适应image.setAutoScale(true);document.add(image);if (i ! size - 1) {// 最后一页不需要新增空白页document.add(new AreaBreak(AreaBreakType.NEXT_PAGE));}}}pdfDocument.close();return true;} catch (Exception e) {logger.error(合并图片到PDF异常:, e);}return false;}/*** 基于内存中的字节数组进行PDF文档的合并* param firstPdf 第一个PDF文档* param secondPdf 第二个PDF文档*/private static byte[] mergePdfBytes(byte[] firstPdf, byte[] secondPdf) throws IOException {if (firstPdf ! null secondPdf ! null) {// 创建字节数组基于内存进行合并ByteArrayOutputStream baos new ByteArrayOutputStream();PdfDocument destDoc new PdfDocument(new PdfWriter(baos));// 合并的pdf文件对象PdfDocument firstDoc new PdfDocument(new PdfReader(new ByteArrayInputStream(firstPdf)));PdfDocument secondDoc new PdfDocument(new PdfReader(new ByteArrayInputStream(secondPdf)));// 合并对象PdfMerger merger new PdfMerger(destDoc);merger.merge(firstDoc, 1, firstDoc.getNumberOfPages());merger.merge(secondDoc, 1, secondDoc.getNumberOfPages());// 关闭文档流merger.close();firstDoc.close();secondDoc.close();destDoc.close();return baos.toByteArray();}return null;}/*** 将pdf文档转换成字节数组* param pdf PDF文档路径* return 返回对应PDF文档的字节数组*/private static byte[] getPdfBytes(String pdf) throws Exception {ByteArrayOutputStream out new ByteArrayOutputStream();InputStream is;if (pdf.startsWith(http://) || pdf.startsWith(https://)) {is new URL(pdf).openStream();} else {is new FileInputStream(pdf);}byte[] data new byte[2048];int len;while ((len is.read(data)) ! -1) {out.write(data, 0, len);}return out.toByteArray();} }2测试类代码 package com.gitcode.itext;import com.gitcode.itext.util.PDFUtil;import java.io.FileNotFoundException; import java.util.ArrayList; import java.util.List;/*** version 1.0.0* Date: 2023/10/4 11:12* Author ZhuYouBin* Description:*/ public class ImageDemo {public static void main(String[] args) throws FileNotFoundException {// 图片合并之后生成的PDF路径String imagePath F:\\pdf-demo\\imagePath.pdf;ListString imageList new ArrayList();imageList.add(F:\\pdf-demo\\01.jpg);imageList.add(F:\\pdf-demo\\02.jpg);// 先合并图片PDFUtil.mergeImagesToPdf(imageList, imagePath);// 在合并PDFString destPath F:\\pdf-demo\\merge.pdf;ListString pdfPath new ArrayList();pdfPath.add(F:\\pdf-demo\\demo01.pdf);pdfPath.add(F:\\pdf-demo\\demo02.pdf);pdfPath.add(imagePath);PDFUtil.mergeMultiplePdfs(pdfPath, destPath);} }3合并效果 到此itext7合并PDF文件就介绍完啦。 综上这篇文章结束了主要介绍使用itext7将多个PDF文件、图片合并成一个PDF文件图片旋转、图片缩放。
http://www.pierceye.com/news/873163/

相关文章:

  • 网站建设维护及使用管理办法营销策划的步骤
  • 优秀网站设计案例在家开个人工作室违法吗
  • 腾讯云建设网站wordpress仿知乎社区
  • 《网站开发技术》模板linchong.wordpress
  • 找做企业网站论文旅游网站建设
  • 类似情侣空间的网站开发seo外推软件
  • 网站建设策划方案怎么写工业品网络营销
  • 上海本地网站建设微信网站怎么建设
  • 江苏华江建设集团网站wordpress开发找工作
  • 家政服务网站源码自己做网站好还是让别人做
  • 手机网站用什么系统做网站在什么地方发帖子呢
  • 虚拟电脑可以做网站吗中国建设行业信息网站
  • 网站设计建设合同公司网页设计实例教程
  • 仿起点小说网站开发网站图片优化工具
  • 在线做logo的网站泉州做网站哪家好
  • 知名企业网站人才招聘情况如何网络系统集成
  • 做灯带的网站重庆有哪些好玩的地方
  • 小孩子做手工做游戏的网站百度账号设置
  • 大庆做网站公司巩义网站建设方案报价
  • 该网站受海外服务器保护品牌营销型网站建设公司
  • 免费做一建或二建题目的网站郑州企业建站系统模板
  • 想自己建个网站徐州做网站软件
  • 蓝色系网站设计企业应对承包商的施工方案尤其是
  • 旅游网站 源码 织梦导购网站开发
  • 头像制作网站开源低代码平台
  • 网站到期域名怎么解决办法自己动手建立网站3
  • 比较有名的网站建设平台吉林建设网站
  • 网站服务器解决方案wamp安装wordpress
  • 义乌制作网站赣州网站建设公司
  • 东莞网站平台后缀建设淘宝客网站