双层PDF的制作 您所在的位置:网站首页 PDF怎样做双层 双层PDF的制作

双层PDF的制作

2024-04-27 14:58| 来源: 网络整理| 查看: 265

双层PDF的制作——使用PDF4NET 3.3.6 实现

        所谓双层PDF就是每一页都包含两层,上层是图像,下层是该图像对应的文字。既可以像图像一样浏览,又可以像文字一样复制、查找。这样兼顾了阅读的效果和使用方便性。

      在Google里面搜索,大多数双层PDF制作方法都是使用OCR技术实现的。这些方法的制作前提是,原始的数据只是图片,不存在对应的文字版。这不在本文的讨论范围内,本文主要探讨如何对已经拥有文字版的word或者其他文件的情况下,制作双层PDF。具体来说就是存在一个排版好的word文件,将这个word文件制作成一个双层PDF。

  闲话少说,具体的制作过程如下

1、将文字版的文件(word)转换为以文本方式存储的PDF文件,这个使用PDFCreator采用虚拟打印的方式即可实现。这里暂定该文件的名称为"w.pdf"。

2、将创建的的文本方式的存储的PDF文件(w.pdf),转换为以图片方式存储的PDF文件。这个可以用PDFCreator的虚拟打印机,先打印成TIFF格式的文件,再将这个TIFF文件虚拟打印成一个PDF的方式实现,这里暂定该图片方式的PDF文件名为“p.pdf”。

3、将文字方式存储的PDF文件和图片方式存储的PDF文件采用按页合并的方式生成一个新的PDF文件,其中图片方式的PDF在上层。这个采用PDF4NET 3.3.6 进行二次开发的方式实现。以下代码为visual studio 2005环境下,使用C#编写。

(1)将O2S.Components.PDF4NET.dll添加到工程的引用中

(2)添加命名空间的引用

using O2S.Components.PDF4NET;using O2S.Components.PDF4NET.PDFFile;using O2S.Components.PDF4NET.Graphics;

(3) 编写代码如下:

            string startTime = System.DateTime.Now.ToString();

            //File1为文字格式的PDF文件            PDFFile File1 = PDFFile.FromFile(@"d:\w.pdf");            //File2为图片格式的PDF文件            PDFFile File2 = PDFFile.FromFile(@"d:\p.pdf");             if(File1.PagesCount!=File2.PagesCount){                MessageBox.Show("Two pdf files with diffrent pages");                return;            }

            PDFDocument doc = new PDFDocument();

            for (int i = 0; i < File1.PagesCount; i++)            {                PDFImportedContent ic1 = File1.ExtractPageContent(i);                PDFImportedContent ic2 = File2.ExtractPageContent(i);

                PDFPage NewPage = doc.AddPage();                PDFLayer NewLayer = NewPage.Canvas.Layers.Add("Page" + i.ToString());

                NewLayer.Canvas.DrawImportedContent(ic1, ic1.X, ic1.Y, ic1.Width, ic1.Height);                NewLayer.Canvas.DrawImportedContent(ic2, ic2.X, ic2.Y, ic1.Width, ic1.Height);

                doc.AddPage(NewPage);

            }            //不知道为什么,合成后的PDF的同一页都包含两份,因此这里需要依次移除其中的一个            if (doc.Pages.Count == File1.PagesCount * 2)            {                for (int i = doc.Pages.Count - 1; i > 0; i -= 2)                {                    doc.Pages.RemoveAt(i);

                }            }            //保存合成后的PDF到文件            doc.SaveToFile(@"d:\123.pdf");            MessageBox.Show("开始时间:" + startTime + "结束时间:" + System.DateTime.Now.ToString());

 PS:试用版的PDF4NET会每一页的顶部添加一行红色的字。PDF4NET还有很多其他的功能,很强大的哦。

 



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有