spire.pdf盖章(无水印免费无限制)

下载老版的spire.pdf.jar,就会在一页有水印,添加一页pdf,然后删掉最后一页就可以了;

jar资源地址:spire.pdf-3.7.4.jar


import java.awt.geom.Rectangle2D;
import java.io.File;
import java.io.IOException;

import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.pdmodel.PDPage;
import org.junit.Test;

import com.spire.pdf.FileFormat;
import com.spire.pdf.PdfDocument;
import com.spire.pdf.PdfPageBase;
import com.spire.pdf.annotations.PdfRubberStampAnnotation;
import com.spire.pdf.annotations.appearance.PdfAppearance;
import com.spire.pdf.graphics.PdfImage;
import com.spire.pdf.graphics.PdfTemplate;
import com.spire.pdf.widget.PdfPageCollection;

public class SomeTest {

  public static void main(String[] args) {

    //创建PdfDocument对象,加载PDF测试文档
    PdfDocument doc = new PdfDocument();
    doc.loadFromFile("xxx.pdf");
    System.out.println(doc.getPages().getCount());
    //添加空白文档
    doc.getPages().add();
    PdfPageCollection pages = doc.getPages();

    System.out.println(pages.getCount());
    for (int i = 0; i < pages.getCount(); i++) {
      PdfPageBase page = doc.getPages().get(i);
      PdfRubberStampAnnotation stamp = getStamp(page);
      //添加图章到PDF
      page.getAnnotationsWidget().add(stamp);
    }
    System.out.println(doc.getPages().getCount());
    //保存文档
    doc.saveToFile("ImageStamp.pdf", FileFormat.PDF);
    //删除空白文档
    removeLast("ImageStamp.pdf");
  }

  private static void removeLast(String filePath) {
    try {
      // 加载PDF文档
      PDDocument document = PDDocument.load(new File(filePath));
      int pageNumberToRemove = document.getPages().getCount() - 1;
      // 获取要删除的页
      PDPage pageToRemove = document.getPage(pageNumberToRemove);

      // 删除页
      document.removePage(pageToRemove);

      // 保存修改后的PDF
      document.save(new File(filePath));

      // 关闭文档
      document.close();

      System.out.println("成功删除第 " + pageNumberToRemove + " 页!");
    } catch (IOException e) {
      e.printStackTrace();
    }
  }


  private static PdfRubberStampAnnotation getStamp(PdfPageBase page) {
    //加载印章图片
    PdfImage image = PdfImage.fromFile("章.png");
    //获取印章图片的宽度和高度
    int width = image.getWidth();
    int height = image.getHeight();

    //创建PdfTemplate对象
    PdfTemplate template = new PdfTemplate(width, height);
    //将图片绘制到模板  要在pdf上调整好大小
    template.getGraphics().drawImage(image, 50, 0, 100, 100);

    //创建PdfRubebrStampAnnotation对象,指定大小和位置
    Rectangle2D rect = new Rectangle2D.Float((float) (page.getActualSize().getWidth() - width - 0),
        (float) (page.getActualSize().getHeight() - height + 50), width, height);

    PdfRubberStampAnnotation stamp = new PdfRubberStampAnnotation(rect);

    //创建PdfAppearance对象
    PdfAppearance pdfAppearance = new PdfAppearance(stamp);
    //将模板应用为PdfAppearance的一般状态
    pdfAppearance.setNormal(template);
    //将PdfAppearance 应用为图章的样式
    stamp.setAppearance(pdfAppearance);
    return stamp;
  }
}

免费Spire.PDF for .NET 是一款由e-iceblue公司开发的专业性的PDF文档创建组件。它能够使用户在不用Adobe Acrobat和其他外部控件的情况下,运用.NET 应用程序阅读,编写和操纵PDF 文档。Spire.PDF for .NET不仅可以运用在服端比如:ASP.NET 或者其他环境,还可以应用在Windows Forms 应用程序中。Spire.PDF for .NET 适合应用于所有常见的坏境中,比如:创建好的PDF文档可以存到磁盘中, 还可以在Windows Forms应用程序,ASP.NET 应用程序客户端浏览器中保存为数据流。 Spire.PDF for .NET 功能丰富。 除了基本的功能比如:绘制多种图形,图片,创建窗体字段,插入页眉页脚,输入数据表,自动对大型表格进行分页外,Spire.PDF for .NET还支持PDF数字签名,将HTML转换成PDF格式,提取PDF文档中的文本信息和图片,存为文本格式和各种图片格式,甚至可以将PDF中的附件提取出来。 主要功能 支持嵌入式字体,Truetype 字体和CJK字体。 支持绘图。比如:矩形,环形,弧形,椭圆形,也可以自定笔刷将其填充。 可以将图片从数据流,磁盘文件中载入到PDF 文档中。 在PDF 文档中既可以绘制梯状图形和矢量图像,还支持掩模和水印图像。 可以在PDF 文档中载入数据表。可以设置表中的行和列的格式,还可以在表内加入图形元素。 自动对PDF 中的大型表格进行分页。 创建窗体字段。比如在PDF 文档中创建按钮,文本框,列表框,复选框等等。 在PDF 中插入页眉页脚。 通过设置所有者密码和用户密码来加密PDF文档。 通过作者的签名来保护PDF文档。 读取当前PDF文档的表格并且填充表格。 HTML网页在转换到PDF文档时会拆分为多个大型页面,这些页面可以原原本本的展现在PDF文档中,而且在PDF文档的分页处没有任何文字的截断。用户还可以将这些网页在不需要临时文件的情况下,直接转换为数据流来创建PDF文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值