RemoveDuplicateImages.cs
// 
// このコードは、DioDocs for PDF のサンプルの一部として提供されています。
// © MESCIUS inc. All rights reserved.
// 
using System;
using System.IO;
using System.Drawing;
using GrapeCity.Documents.Pdf;
using GrapeCity.Documents.Pdf.Annotations;
using System.Collections.Generic;

namespace DsPdfWeb.Demos
{
    // 同一の画像を含む PDF を結合すると、デフォルトでは、
    // 結果の PDF には同じ画像のコピーが複数含まれることになります。
    // PDF が必要以上に大きくならないようにするために、DsPdf は PDF をスキャンし、
    // 重複を見つけて削除するメソッド GcPdfDocument.RemoveDuplicateImages() を提供します。
    // MergeDocumentOptions クラスには RemoveDuplicateImages プロパティもあります。
    // これを使用すると、PDF を結合するときに重複を一度にスキャン/削除できます。
    // しかし、デフォルトでは false です。これは、結合された PDF で重複イメージが発生することは
    // あまり一般的なシナリオではない一方で、重複のスキャンが結合のパフォーマンスに影響を与える可能性があるためです。
    // また、重複した画像を含む複数の PDF を結合する場合は、最初にすべての PDF を結合することをお勧めします。
    // and then remove all duplicates from the final PDF at once with a single call to
    // 次に、このデモで示されているように、GcPdfDocument.RemoveDuplicateImages() を 1 回呼び出すだけで、
    // 最終的な PDF からすべての重複を一度に削除します。
    //
    // このデモでは、同じ会社ロゴを含む複数のサンプル請求書を結合します。
    // 次に、GcPdfDocument.RemoveDuplicateImages() を呼び出し、その呼び出しの前後で結果の PDF のサイズを比較します。
    // 
    // OptimizeFonts も参照してください。
    public class RemoveDuplicateImages
    {
        static FileStream MergePDFs(GcPdfDocument dest, string fpath)
        {
            GcPdfDocument d = new GcPdfDocument();
            var fs = File.OpenRead(fpath);
            d.Load(fs);
            dest.MergeWithDocument(d);
            return fs;
        }

        public int CreatePDF(Stream stream)
        {
            // 入力ファイル名:
            const int N = 7;
            var fpaths = new List<string>(N);
            for (int i = 1; i <= 7; i++)
                fpaths.Add(Path.Combine("Resources", "PDFs", $"DsDemoInvoice{i}.pdf"));
            // クリーンアップを促進
            var fss = new List<FileStream>();
            string tempPdfBefore = null, tempPdfAfter = null;
            try
            {
                var doc = new GcPdfDocument();
                // 請求書を 1 つの PDF に結合:
                for (int i = 0; i < N; i++)
                    fss.Add(MergePDFs(doc, fpaths[i]));

                // 重複を削除する前と後の、結合された PDF サイズを比較:
                tempPdfBefore = Path.GetTempFileName();
                doc.Save(tempPdfBefore);
                var sizeBefore = new FileInfo(tempPdfBefore).Length;
                doc.RemoveDuplicateImages();
                tempPdfAfter = Path.GetTempFileName();
                doc.Save(tempPdfAfter);
                var sizeAfter = new FileInfo(tempPdfAfter).Length;
                Common.Util.AddNote(String.Format(
                    "このドキュメント (マージによって生成された) で GcPdfDocument.RemoveDuplicateImages() メソッドを使用します。" +
                    "同じ会社ロゴを持つ複数のデモ請求書PDFのサイズが {0:N0} バイトから {1:N0} バイトに減少しました。",
                    sizeBefore, sizeAfter),
                    doc.Pages.Insert(0));
                doc.Save(stream);
                return doc.Pages.Count;
            }
            finally
            {
                if (tempPdfBefore != null)
                    File.Delete(tempPdfBefore);
                if (tempPdfAfter != null)
                    File.Delete(tempPdfAfter);
                fss.ForEach(fs_ => fs_.Dispose());
            }
        }
    }
}