pdf打印骑缝章

news/2025/3/16 6:09:06/

骑缝章是用于往来业务合同,以确保合同真实、有效的印章加盖方法,是一种防范风险的重要方式。在Java程序中,可以通过使用工具来辅助加盖这种骑缝章。

工具:Free Spire.PDF for Java (免费版)

工具获取及jar文件导入:

方式1通过官网下载jar包,并解压,手动导入lib文件夹下的Spire.Pdf.jar文件。

方式2通过创建Maven程序,在pom.xml中配置maven仓库路径并指定Free Spire.PDF for Java 的依赖,配置完成后,在IDEA中,点击“Import Changes”导入JAR包:

复制代码

<repositories><repository><id>com.e-iceblue</id><url>http://repo.e-iceblue.cn/repository/maven-public/</url></repository>
</repositories><dependencies><dependency><groupId>e-iceblue</groupId><artifactId>spire.pdf.free</artifactId><version>2.6.3</version></dependency>
</dependencies>

复制代码

(Ecllipse的导入方法,参考这篇文章

jar导入结果如下图所示:

 

 

Java 示例

复制代码

import com.spire.pdf.*;
import com.spire.pdf.graphics.PdfGraphicsUnit;
import com.spire.pdf.graphics.PdfImage;
import com.spire.pdf.graphics.PdfUnitConvertor;import javax.imageio.ImageIO;
import java.awt.*;
import java.awt.geom.Point2D;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;public class AcrossPageSeal {public static void main(String[] args) throws IOException {//加载测试文档PdfDocument pdf = new PdfDocument();pdf.loadFromFile("test.pdf");//获取分割后的印章图片BufferedImage[] images = GetImage(pdf.getPages().getCount());float x = 0;float y = 0;//实例化PdfUnitConvertor类PdfUnitConvertor convert = new PdfUnitConvertor();PdfPageBase pageBase;//将图片绘制到PDF页面上的指定位置for (int i = 0; i < pdf.getPages().getCount(); i++){BufferedImage image= images[ i ];pageBase = pdf.getPages().get(i);x = (float)pageBase.getSize().getWidth() - convert.convertUnits(image.getWidth(), PdfGraphicsUnit.Point, PdfGraphicsUnit.Pixel) + 40;y = (float) pageBase.getSize().getHeight()/ 2;pageBase.getCanvas().drawImage(PdfImage.fromImage(image), new Point2D.Float(x, y));}//保存PDF文档pdf.saveToFile("Result.pdf");}//定义GetImage方法,根据PDF页数分割印章图片static BufferedImage[] GetImage(int num) throws IOException {String originalImg = "seal.png";BufferedImage image = ImageIO.read(new File(originalImg));int rows = 1;int cols = num;int chunks = rows * cols;int chunkWidth = image.getWidth() / cols;int chunkHeight = image.getHeight() / rows;int count = 0;BufferedImage[] imgs = new BufferedImage[ chunks ];for (int x = 0; x < rows; x++) {for (int y = 0; y < cols; y++) {imgs[ count ] = new BufferedImage(chunkWidth, chunkHeight, image.getType());Graphics2D gr = imgs[ count++ ].createGraphics();gr.drawImage(image, 0, 0, chunkWidth, chunkHeight,chunkWidth * y, chunkHeight * x,chunkWidth * y + chunkWidth, chunkHeight * x + chunkHeight, Color.WHITE,null);gr.dispose();}}return imgs;}}

复制代码

骑缝章添加效果:

 

参考:Java 在PDF中添加骑缝章 - E-iceblue - 博客园 (cnblogs.com)


http://www.ppmy.cn/news/789085.html

相关文章

【算法集训之线性表篇】Day 05

文章目录 题目一思路代码实现效果题目二思路代码实现效果 题目一 将两个有序顺序表合并为一个有序顺序表&#xff0c;函数结果返回值为顺序表。 思路 我们可以利用二路归并排序算法中的Merge函数思路&#xff0c;设置两个指针i&#xff0c;j&#xff0c;分别记录在顺序表a和…

基于matlab使用PointNet深度学习进行点云分类(附源码)

一、前言 此示例演示如何训练 PointNet 网络以进行点云分类。 点云数据由各种传感器获取&#xff0c;例如激光雷达、雷达和深度摄像头。这些传感器捕获场景中物体的3D位置信息&#xff0c;这对于自动驾驶和增强现实中的许多应用非常有用。例如&#xff0c;区分车辆和行人对于…

maxwell生成动态磁力线/磁密云图一些报错警告解决办法

之前看到一个动态变化的磁密云图以及磁力线动图&#xff0c;如图1、2所示&#xff0c;觉得很好玩。 图1 动态磁密云图 图2 动态磁力线图 这个可以在Maxwell软件直接获取&#xff0c;步骤如下&#xff1a; 首先在电机瞬态仿真的时候设置Solve setup的时候注意save fileds一栏…

【超详细】磁力计数据读取--以IST8310为例

这里以iSentek公司产出的IST8310型号的磁力计为例&#xff0c;尺寸为 3.0 * 3.0 * 1.0mm&#xff0c;支持快速 I2C 通信&#xff0c;可达 400kHz&#xff0c;14 位磁场数据&#xff0c;测量范围可达1600uT(x,y-axis)和 2500uT(z-axis)&#xff0c; 最高 200Hz 输出频率 同时这里…

Python简单爬取电影磁力链接

Python简单爬取电影磁力链接 网页的链接&#xff1a;http://www.ygdy8.net/html/gndy/dyzz/list_23_2.html 打开你想要的电影&#xff1a;http://www.ygdy8.net/html/gndy/dyzz/20181124/57807.html 找到下载地址&#xff1a; 代码&#xff1a; import requests#网络请求模块…

[初学Python]利用某网站的功能写一个磁力链转种子工具

孔子曰&#xff1a;学而时习之~ 初学python&#xff0c;一边看语法&#xff0c;一边看参考例程&#xff0c;写了一个小程序&#xff0c;做个存档&#xff0c;否则很容易忘记。 这次的目标是利用某种子下载网站&#xff0c;编写一个磁力链下载种子文件的工具。 常见的种子文件…

磁力块(分块)

题目链接 输入格式 第一行五个整数 x 0 , y 0 , p L , r L , N x_0,y_0,p_L,r_L,N x0​,y0​,pL​,rL​,N&#xff0c;表示小取酒所在的位置&#xff0c;磁石 L L L 磁力、吸引半径和原野上散落磁石的个数。 接下来 N N N 行每行五个整数 x , y , m , p , r x,y,m,p,r x,…

海洋磁力数据处理步骤

​ &#xff08;此照片乃航次获奖照片&#xff09; 前面几个章节介绍了地磁基本知识&#xff0c;由于项目紧急&#xff0c;只能边学习理论&#xff0c; 边处理。经过2个月的努力&#xff0c;基本上掌握了海洋重磁处理的基本方法。 目前&#xff0c;专项的重磁处理都是各单位自己…