// 获得pdf页数
int pdfPage = DocUtil.getPdfPage(filePath); //指定将和 图片拼接的 PDF
// 获取第一页宽和高
PdfReader pdfreader = new PdfReader(filePath);
Document document = new Document(pdfreader.getPageSize(1));
// 获取页面宽度
float width = document.getPageSize().getWidth();
// 获取页面高度
float height = document.getPageSize().getHeight();
if ( pdfreader != null)
pdfreader.close();
if ( document != null)
document.close();
System.out.println("width = "+width+", height = "+height);
String picturePath; //图片路径
PdfReader pdf = new PdfReader(filePath);
PdfStamper stamper = null;
try {
stamper = new PdfStamper(pdf, new FileOutputStream(outPath));//生成的PDF 路径 outPath
for (int i = 1 ;i <= pdfPage; i++){
PdfContentByte overContent = stamper.getOverContent(i);
picturePath = file + "/wordTemplate/"+"cutContract"+i+".png";
// 剪切图片
File directory = new File("");// 参数为空
String courseFile = directory.getCanonicalPath();
DocUtil.cutPicture("png",courseFile+"\\src\\main\\webapp\\WEB-INF\\docPicture\\contract.png",113/pdfPage*(i-1),0,113/pdfPage,113,picturePath);
//添加图片
com.itextpdf.text.Image image = com.itextpdf.text.Image.getInstance(picturePath);//图片名称
image.setAbsolutePosition((int)width-113/pdfPage,(int)height/2);//左边距、底边距
overContent.addImage(image);
overContent.stroke();
}
} catch (Exception e){
e.printStackTrace();
} finally {
try {
if (null != stamper ){
stamper.close();
}
if (pdf != null){
pdf.close();
}
} catch (Exception e){
e.printStackTrace();
}
}
public static void cutPicture(String lastDir, String srcPath, int x, int y, int width,
int height, String subPath) throws IOException {
FileInputStream is = null;
ImageInputStream iis = null;
try {
// 读取图片文件
is = new FileInputStream(srcPath);
/*
* 返回包含所有当前已注册 ImageReader 的 Iterator,这些 ImageReader 声称能够解码指定格式。
* 参数:formatName - 包含非正式格式名称 .(例如 "jpeg" 或 "tiff")等 。
*/
Iterator<ImageReader> it = ImageIO.getImageReadersByFormatName(lastDir);
ImageReader reader = it.next();
// 获取图片流
iis = ImageIO.createImageInputStream(is);
/*
* <p>iis:读取源.true:只向前搜索 </p>.将它标记为 ‘只向前搜索’。
* 此设置意味着包含在输入源中的图像将只按顺序读取,可能允许 reader 避免缓存包含与以前已经读取的图像关联的数据的那些输入部分。
*/
reader.setInput(iis, true);
/*
* <p>描述如何对流进行解码的类<p>.用于指定如何在输入时从 Java Image I/O
* 框架的上下文中的流转换一幅图像或一组图像。用于特定图像格式的插件 将从其 ImageReader 实现的
* getDefaultReadParam 方法中返回 ImageReadParam 的实例。
*/
ImageReadParam param = reader.getDefaultReadParam();
/*
* 图片裁剪区域。Rectangle 指定了坐标空间中的一个区域,通过 Rectangle 对象
* 的左上顶点的坐标(x,y)、宽度和高度可以定义这个区域。
*/
Rectangle rect = new Rectangle(x, y, width, height);
// 提供一个 BufferedImage,将其用作解码像素数据的目标。
param.setSourceRegion(rect);
/*
* 使用所提供的 ImageReadParam 读取通过索引 imageIndex 指定的对象,并将 它作为一个完整的
* BufferedImage 返回。
*/
BufferedImage bi = reader.read(0, param);
// 保存新图片
ImageIO.write(bi, lastDir, new File(subPath));
} finally {
if (is != null)
is.close();
if (iis != null)
iis.close();
}
}