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

双层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还有很多其他的功能,很强大的哦。

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/togis/archive/2009/05/26/4218789.aspx

原文地址:https://www.cnblogs.com/gisoracle/p/2015768.html