利用Spire.Pdf实现PDF添加印章的操作

利用,spire,pdf,实现,添加,印章,操作 · 浏览次数 : 619

小编点评

**代码示例:** ```csharp public static void SplitSign(string signPdf, string signImage, string fileSave) { // 加载 PDF 文档 PdfDocument doc = new PdfDocument(); doc.LoadFromFile(signPdf); // 获取分割后的印章图片 Image[] images = GetImage(doc.Pages.Count, signImage); // 设置透明比例 float x = 0; float y = 0; float alpha = 0.5f; // 对每页的 PDF 文档进行处理 for (int i = 0; i < doc.Pages.Count; i++) { // 获取 PDF 页面 PdfPageBase pageBase = doc.Pages[i]; // 设置位置 x = pageBase.Size.Width - convert.ConvertToPixels(images[i].Width, PdfGraphicsUnit.Point); y = 150; //页面高度的一半 // 绘制图片 pageBase.Canvas.SetTransparency(alpha, alpha, PdfBlendMode.Normal); pageBase.Canvas.DrawImage(PdfImage.FromImage(images[i]), new PointF(x, y)); } // 保存 PDF 文件 if (!string.IsNullOrEmpty(fileSave)) { doc.SaveToFile(fileSave); } doc.Close(); } ``` **其他说明:** * `GetImage()` 函数用于根据分割数量和图片路径获取图片列表。 * `PdfImage.FromImage()` 函数用于将图像转换为 PDF 图像。 * `PdfUnitConvertor` 类用于处理 PDF 文档的转换。 * `RectangleF` 类用于定义图片绘制的区域。

正文

在一些文档处理中,我们需要对PDF盖上公司的印章操作,本篇随笔介绍利用Spire.Pdf实现PDF添加印章的操作,如全章和骑缝章的处理。

1、实现效果和处理代码

有时候,需要在特定的位置盖章,以及各个页面盖上骑缝章,如下界面效果所示。

全章的位置定位好后,绘制一个图片即可,骑缝章则是根据多少页,把图片拆分来,然后每页指定位置绘制上图片就可以,逻辑上相对比较简单,只需要便于对PDF实现相关的处理即可。

如需要对PDF文档进行编辑处理,那么我们需要对PDF文档进行加载,使用Spire.Pdf控件对PDF文件处理比较容易。

首先是根据文档路径加载为PdfDocument对象,如下代码所示。

   var doc = new PdfDocument();
   doc.LoadFromFile(signPdf);

而图片内容,我们这需要根据图片路径,进行加载,由于图片大小有不一样的地方,因此需要根据缩放到指定的大小进行粘贴,如下代码所示。

    //构建印章图片,并进行缩放裁剪
    var image = Image.FromFile(signImage);
    image = ImageHelper.ResizeImageToAFixedSize(image, imageWidth, imageHeight, ImageHelper.ScaleMode.H, Color.White);
    PdfImage pdfImage = PdfImage.FromImage(image);

然后对每页的PDF文档,进行单独的处理。

    //每页都添加印章
    for (int i = 0; i < doc.Pages.Count; i++)

由于PDF文档,可以通过绘制 PdfTemplate 模板的方式贴上所需要的内容,如我们这里是图片,代码所示。

    PdfPageBase page = doc.Pages[i];

    //使用PdfTemplate模板绘制,可以拖动或锁定
    var loStamp = new PdfRubberStampAnnotation(new RectangleF(new PointF(400, 600), new SizeF(imageWidth, imageHeight)));
    var loApprearance = new PdfAppearance(loStamp);
    var template = new PdfTemplate(imageWidth, imageHeight);
    template.Graphics.DrawImage(pdfImage, 0, 0);
    loApprearance.Normal = template;
    loStamp.Appearance = loApprearance;
    loStamp.Flags = PdfAnnotationFlags.ReadOnly | PdfAnnotationFlags.NoRotate | PdfAnnotationFlags.NoZoom | PdfAnnotationFlags.Locked; // 设置印章标志
    page.AnnotationsWidget.Add(loStamp);

最后保存文档并关闭对象即可。

    //保存文档
    if (!string.IsNullOrEmpty(fileSave))
    {
        doc.SaveToFile(fileSave);
    }
    doc.Close();

以上就是在特定位置粘贴图片,实现印章处理的代码逻辑。

 

2、实现骑缝章的处理

骑缝章的处理类似,主要就是先拆分图片,如下是图片拆分的实现代码。

        /// <summary>
        /// 把图片根据份数进行拆分不同的图片集合
        /// </summary>
        /// <param name="num">多少份</param>
        /// <param name="signImage">图片路径</param>
        /// <returns></returns>
        private static Image[] GetImage(int num, string signImage)
        {
            var lists = new List<Bitmap>();
            var imageWidth = 150;
            var imageHeight = 150;
            var image = Image.FromFile(signImage);
            image = ImageHelper.ResizeImageToAFixedSize(image, imageWidth, imageHeight, ImageHelper.ScaleMode.H, Color.White);

            int w = image.Width / num;
            Bitmap bitmap = null;
            for (int i = 0; i < num; i++)
            {
                bitmap = new Bitmap(w, image.Height);
                using (Graphics g = Graphics.FromImage(bitmap))
                {
                    g.Clear(Color.White);

                    var rect = new Rectangle(i * w, 0, w, image.Height);
                    g.DrawImage(image, new Rectangle(0, 0, bitmap.Width, bitmap.Height), rect, GraphicsUnit.Pixel);
                }
                lists.Add(bitmap);
            }
            return lists.ToArray();
        }

最后实现代码如下所示。

/// <summary>
/// 生成骑缝章
/// </summary>
/// <param name="signPdf">要盖章的文件</param>
/// <param name="signImage">印章图片</param>
/// <param name="fileSave">处理后的文件保存路径</param>
public static void SplitSign(string signPdf, string signImage, string fileSave)
{
    //加载PDF文档 
    var doc = new PdfDocument();
    doc.LoadFromFile(signPdf);

    var convert = new PdfUnitConvertor();

    //获取分割后的印章图片
    Image[] images = GetImage(doc.Pages.Count, signImage);
    float x = 0;
    float y = 0;
    float alpha = 0.5f;//设定透明比例

    //将图片画到PDF页面上的指定位置
    PdfPageBase pageBase = null;
    for (int i = 0; i < doc.Pages.Count; i++)
    {
        pageBase = doc.Pages[i];
        x = pageBase.Size.Width - convert.ConvertToPixels(images[i].Width, PdfGraphicsUnit.Point);
        y = 150; //pageBase.Size.Height / 2;//中间靠上一点
        pageBase.Canvas.SetTransparency(alpha, alpha, PdfBlendMode.Normal);//设置透明度
        pageBase.Canvas.DrawImage(PdfImage.FromImage(images[i]), new PointF(x, y));
    }

    //保存PDF文件
    if (!string.IsNullOrEmpty(fileSave))
    {
        doc.SaveToFile(fileSave);
    }
    doc.Close();
}

    

三个页面的骑缝章如上所示。

 

与利用Spire.Pdf实现PDF添加印章的操作相似的内容:

利用Spire.Pdf实现PDF添加印章的操作

在一些文档处理中,我们需要对PDF盖上公司的印章操作,本篇随笔介绍利用Spire.Pdf实现PDF添加印章的操作,如全章和骑缝章的处理。

Python 调整PDF页面尺寸大小

在处理PDF文件时,我们可能会遇到这样的情况:原始PDF文档不符合我们的阅读习惯,或者需要适配不同显示设备等。这时,我们就需要及时调整PDF文档中的页面尺寸,以满足不同应用场景的需求。 利用Python语言的高效性和灵活性,再结合Spire.PDF for Python 库的强大功能,我们可以通过P

Python 提取PDF文本和图片

从PDF中提取内容能帮助我们获取文件中的信息,以便进行进一步的分析和处理。此外,在遇到类似项目时,提取出来的文本或图片也能再次利用。要在Python中通过代码提取PDF文件中的文本和图片,可以使用 Spire.PDF for Python 这个第三方库。具体操作方法查阅下文。 Python 提取PD

利用Wireshark抓包分析DNS域名解析过程

一、DNS协议概述 DNS协议也可以称为DNS服务,全称是Domain Name System,即域名系统,和HTTP协议一样,也是一个位于应用层的协议(服务),它是基于运输层的UDP协议的。从DNS的名字我们就可以知道,它提供域名映射到IP地址的服务。 二、实验目的 掌握DNS域名解析过程 熟悉D

利用大型语言模型轻松打造浪漫时刻

在这篇文章中,我们介绍了如何利用大型语言模型为情人节营造难忘的氛围。通过上传图片并进行风格转化,我们可以为对方呈现一幅独特的作品,增添浪漫的色彩。同时,借助搜索功能,我们能够轻松获取与情人节相关的信息,为策划活动提供更多灵感和建议。

利用英特尔 Gaudi 2 和至强 CPU 构建经济高效的企业级 RAG 应用

检索增强生成 (Retrieval Augmented Generation,RAG) 可将存储在外部数据库中的新鲜领域知识纳入大语言模型以增强其文本生成能力。其提供了一种将公司数据与训练期间语言模型学到的知识分开的方式,有助于我们在性能、准确性及安全隐私之间进行有效折衷。 通过本文,你将了解到英特

利用深度循环神经网络对心电图降噪

具体的软硬件实现点击 http://mcu-ai.com/ MCU-AI技术网页_MCU-AI 我们提出了一种利用由长短期记忆 (LSTM) 单元构建的深度循环神经网络来降 噪心电图信号 (ECG) 的新方法。该网络使 用动态模型 ECG 生成的合成数据进行预训 练,并使用来自 Physionet

利用pearcmd实现裸文件包含

title: 利用pearcmd实现裸文件包含 tags: [web,文件包含] categories: [CTF,web] 利用pearcmd实现裸文件包含 在 ctf 中,常常有这样一类题: 题目很简单,一般围绕一个 include 函数展开。 例: ctfshow 元旦水友赛 easy_inc

利用pip/conda安装库时,出现requires XXX, which is not installed/incompatible

博客地址:https://www.cnblogs.com/zylyehuo/ 出现以下提示警告时 step1 step2 step3 总结 利用pip/conda安装库时,出现requires XXX, which is not installed/incompatible 依次执行安装所缺的库即可

利用队列的内置模块(deque)模拟 Linux 下的 tail 命令(输出文件中最后几行的内容)

博客地址:https://www.cnblogs.com/zylyehuo/ # -*- coding: utf-8 -*- from collections import deque def tail(n): # n:指定输出文件中最后几行 with open('test.txt', 'r') a