0

0

如何在 OpenPDF 中实现印章图像浮于文字之上的效果

花韻仙語

花韻仙語

发布时间:2026-02-10 11:03:20

|

850人浏览过

|

来源于php中文网

原创

如何在 OpenPDF 中实现印章图像浮于文字之上的效果

本文详解如何利用 openpdf 的 `pdfstamper` 与页面覆层(over content)机制,将印章等图像精确、动态地叠加在 pdf 文本上方,支持绝对定位与分页适配,满足合同签署等实际业务需求。

在 OpenPDF 中,Image 类内置的定位常量(如 UNDERLYING、TEXTWRAP、LEFT 等)仅适用于文档构建阶段(即通过 Document.add() 插入图像),且均无法实现“图像覆盖在已有文本之上”的视觉效果——这正是电子合同加盖公章、签名章等典型场景的核心需求。关键在于:浮层印章不属于文档流内容,而应作为独立图层绘制在页面最上层

OpenPDF 提供了成熟可靠的解决方案:使用 PdfStamper 对已有 PDF 进行编辑,并通过其 getOverContent(int page) 方法获取指定页的覆层画布(PdfContentByte)。该画布默认位于页面所有内容(包括正文、表格、原有图像)的顶层,因此在其上绘制的图像天然“浮于文字之上”,且支持像素级绝对坐标控制。

图想浪漫
图想浪漫

AI驱动的智能图片编辑解压娱乐站

下载

✅ 正确实现步骤(含代码示例)

import com.lowagie.text.Image;
import com.lowagie.text.pdf.PdfContentByte;
import com.lowagie.text.pdf.PdfReader;
import com.lowagie.text.pdf.PdfStamper;

import java.io.FileOutputStream;
import java.io.IOException;

public class SealOverlayExample {
    public static void addSealToPage(String srcPdf, String destPdf, String sealImagePath,
                                     float x, float y, float width, float height, int page) 
            throws IOException {
        PdfReader reader = new PdfReader(srcPdf);
        PdfStamper stamper = new PdfStamper(reader, new FileOutputStream(destPdf));

        // 获取目标页的覆层(OVER CONTENT),确保图像绘制在最上层
        PdfContentByte overContent = stamper.getOverContent(page);

        // 加载印章图像并设置尺寸与位置(坐标原点为左下角,y 向上为正)
        Image seal = Image.getInstance(sealImagePath);
        seal.scaleAbsolute(width, height);
        seal.setAbsolutePosition(x, y); // x: 距左边界距离;y: 距底边界距离

        // 将图像写入覆层
        overContent.addImage(seal);

        stamper.close();
        reader.close();
    }

    // 示例调用:在第1页 (page=1) 左上区域添加 80×80 像素印章
    public static void main(String[] args) throws Exception {
        addSealToPage(
            "contract.pdf", 
            "contract_with_seal.pdf", 
            "seal.png",
            450f,   // x = 距左边界 450 单位(1 unit ≈ 1/72 inch)
            750f,   // y = 距底边界 750 单位 → 实际显示在页面顶部偏右位置
            80f,    // 宽度
            80f,    // 高度
            1       // 第1页
        );
    }
}

⚠️ 关键注意事项

  • 坐标系理解:OpenPDF 使用 PDF 标准坐标系——原点 (0, 0) 在页面左下角,y 轴向上增长。若需将印章置于“右下角”,x 应接近 pageWidth,y 应接近 0;置于“右上角”则 x 接近 pageWidth,y 接近 pageHeight。
  • 动态定位策略:因合同正文长度可变,建议结合 PdfReader 获取页面尺寸(reader.getPageSize(page).getWidth()/getHeight()),再按比例计算坐标(如 x = pageWidth - 120f, y = pageHeight - 100f),或解析文本块位置(需配合 PdfTextExtractor 或 LocationTextExtractionStrategy)实现智能锚定。
  • 分页处理:PdfStamper 支持逐页操作。若印章需跨多页(如每页页脚加盖骑缝章),需循环调用 getOverContent(i) 并分别绘制。
  • 图像格式兼容性:推荐使用 PNG(支持透明背景)或 JPEG。确保路径有效,且图像资源已正确加载(Image.getInstance(...) 可能抛出 IOException)。
  • 性能与内存:PdfStamper 会加载整个 PDF 到内存,处理大型文件时注意 JVM 堆配置;操作完成后务必调用 stamper.close() 和 reader.close() 释放资源。

✅ 总结

OpenPDF 本身不提供 Image.OVERLAY 这类语义化常量,但通过 PdfStamper#getOverContent() 这一底层机制,开发者可完全掌控图像的渲染层级与空间位置。该方案不仅满足“印章浮于文字之上”的刚性需求,更具备高精度、可编程、易集成的特点,是电子签章、PDF 批注、水印嵌入等场景的标准实践路径。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1541

2023.10.24

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

668

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

555

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

193

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

205

2025.08.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

406

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

585

2023.08.10

TensorFlow2深度学习模型实战与优化
TensorFlow2深度学习模型实战与优化

本专题面向 AI 与数据科学开发者,系统讲解 TensorFlow 2 框架下深度学习模型的构建、训练、调优与部署。内容包括神经网络基础、卷积神经网络、循环神经网络、优化算法及模型性能提升技巧。通过实战项目演示,帮助开发者掌握从模型设计到上线的完整流程。

0

2026.02.10

Vue3组合式API与组件开发实战
Vue3组合式API与组件开发实战

本专题讲解 Vue 3 组合式 API 的核心概念与应用技巧,深入分析响应式系统、生命周期管理、组件设计与复用策略。通过完整项目案例,指导前端开发者实现高性能、结构清晰的 Vue 应用,提升开发效率与代码可维护性。

2

2026.02.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号