pdf指定位置插入图片,不改变原格式,直接操作pdf。

// 获得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();
    }
}

猜你喜欢

转载自blog.csdn.net/qq_41497111/article/details/80319370