iTextSharp объединяет и сохраняет плагины - PullRequest
1 голос
/ 19 июля 2011

У меня есть PDF, который имеет плагин управления на одной странице.Мне нужно объединить его с другим PDF, но когда я это сделаю, плагин перерисовывается как пустой прямоугольник.Есть ли способ объединить и сохранить контроль над плагином?Если важно, плагин представляет собой элемент управления Dessault Systemes 3D через Composer Player, установленный с http://www.3ds.com/products/3dvia/3dvia-composer/resource-center/

Код, который я использую, - это простой сценарий getinstance, contentbyte directcontent, getimportedpage, addtemplate.Ничего особенного.

FileStream docStream = new FileStream(@"C:\Temp\Merged.pdf", FileMode.Create);
            Document newDocument = new Document(PageSize.A4.Rotate());
            PdfWriter pdfWriter = PdfWriter.GetInstance(newDocument, docStream);
        try
        {
            newDocument.Open();
            PdfContentByte pdfContentByte = pdfWriter.DirectContent;

            newDocument.NewPage();
            PdfReader mainPage = new PdfReader(@"C:\Temp\PageWithPlugin.pdf");
            PdfImportedPage importedPage1 = pdfWriter.GetImportedPage(mainPage, 1);
            pdfContentByte.AddTemplate(importedPage1, 0, 0);
            mainPage.Close();

            PdfReader smgPages = new PdfReader(@"C:\Temp\MorePages.pdf");
            for (int page = 1; page <= smgPage.NumberOfPages; page++)
            {
                newDocument.NewPage();
                PdfImportedPage importedPage = pdfWriter.GetImportedPage(smgPages, page);
                pdfContentByte.AddTemplate(importedPage, 0, 0);
            }
            smgPages.Close();

            }
        finally
        {
            docStream.Flush();
            if (newDocument != null)
                newDocument.Close();
            docStream.Close();
        }

Ответы [ 2 ]

2 голосов
/ 19 июля 2011

Попробуйте.

List<byte[]> fileList = new List<byte[]>();

using (FileStream fileSteam = File.OpenRead((@"C:\Temp\PageWithPlugin.pdf")))
{
     Byte[] byteArray = new byte[fileSteam.Length];
     fileSteam.Read(byteArray, 0, byteArray.Length);

     fileList.Add(byteArray);
}

using (FileStream fileSteam = File.OpenRead((@"C:\Temp\MorePages.pdf")))
{
     Byte[] byteArray = new byte[fileSteam.Length];
     fileSteam.Read(byteArray, 0, byteArray.Length);

     fileList.Add(byteArray);
}

using(MemoryStream msOutput = new MemoryStream())
{
     PdfReader pdfFile = new PdfReader(fileList[0]);
     Document doc = new Document();
     PdfWriter pCopy = new PdfSmartCopy(doc, msOutput);

     doc.Open();

     for (int k = 0; k < fileList.Count; k++)
     {
         for (int i = 1; i < pdfFile.NumberOfPages + 1; i++)
         {
             pdfFile = new PdfReader(fileList[k]);
             ((PdfSmartCopy)pCopy).AddPage(pCopy.GetImportedPage(pdfFile, i));
             pCopy.FreeReader(pdfFile);
         }
     }

     pdfFile.Close();
     pCopy.Close();
     doc.Close();
     fileList.Clear();

     byte[] form = msOutput.ToArray();

     using (FileStream fileSteam = new FileStream(@"C:\Temp\Merged.pdf", FileMode.Create))
     {
          fileStream.Write(form, 0, form.Length);
     }
}
0 голосов
/ 20 июля 2011

Не смотреть коню в подарок, но ... В случае, если кто-то еще использует решение, есть небольшая проблема с петлей k. Число страниц будет отключено одним документом после нулевого, и pdfReader будет освобождаться и перечитывать для каждой страницы, что не является необходимым. Я думаю, что это улучшение для этой части кода:

using (MemoryStream msOutput = new MemoryStream())
            {
                Document doc = new Document();
                PdfWriter pCopy = new PdfCopy(doc, msOutput);
                doc.Open();
                for (int k = 0; k < fileList.Count; k++)
                {
                    PdfReader pdfFile = new PdfReader(fileList[k]);                        
                    for (int i = 1; i < pdfFile.NumberOfPages + 1; i++)
                    {
                        ((PdfCopy)pCopy).AddPage(pCopy.GetImportedPage(pdfFile, i));
                    }
                    pCopy.FreeReader(pdfFile);
                    pdfFile.Close();
                }
                pCopy.Close();
                doc.Close();
                fileList.Clear();
...