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

namespace DsPdfWeb.Demos
{
    // このサンプルでは、URL で指定された Web ページを PDF にレンダリングする方法を紹介しています。 
    // ここでは、WordIndex サンプルの C# ソースをレンダリングします。
    // このサンプルでは、HtmlRenderPage0 と同様に、レンダリングに SaveAsPdf メソッドを使用しますが、
    // ページの向き、余白、ヘッダー/フッターなどのオプションも指定しています。
    // 
    // ちなみに、次のマークアップ拡張機能をヘッダーテンプレートとタイトルテンプレート
    // で使用できます(このサンプルでは、タイトル以外はすべて使用されます)。
    // - <span class = "date"> - フォーマットされた日付
    // - <span class = "title"> - ドキュメントのタイトル
    // - <span class = "url"> - ドキュメントの場所
    // - <span class = "pageNumber"> - 現在のページ番号
    // - <span class = "totalPages"> - 総ページ数
    // 
    // ヘッダー/フッターでは、画像をリンクとして指定することはできませんが、このサンプルで
    // 示すように、base64 でエンコードされたデータはサポートされています。
    // 
    // また、ヘッダー/フッターの背景色を表示するには、次の Webkit CSS 拡張機能を指定する
    // 必要があります。
    // -webkit-print-color-adjust: exact;
    // 
    // DsHtml をプロジェクトに追加する方法の詳細については、HelloWorldHtml
    // サンプルコードの上部にあるコメントのメモを参照してください。
    public class HtmlSettings
    {
        public void CreatePDF(Stream stream)
        {
            // Web ページがレンダリングされる一時ファイルを取得します。
            var tmp = Path.GetTempFileName();
            // レンダリングする Web ページの Uri。
            var uri = new Uri(@"https://demo.mescius.jp/diodocs/pdf/view-source-cs/word-index/");
            // フッターテンプレートで使用される画像。
            var image = @"";

            // PdfOptions は、HTML から PDF への変換のオプションを設定するために使用されます。
            // - PageRanges では、どのページを含めるかを指定します。
            // - PageWidth/PageHeight では、ページサイズをカスタマイズできます(ここではデモのためデフォルトを使用しています)。
            // - Margins では、ページの余白を指定します(デフォルトは余白なしです)。
            // - Landscape では、ページの向きを変更することができます。
            // - Scale では、レンダリングサイズを拡大または縮小できます(デフォルトは1)。
            // - 独自のヘッダー/フッターを追加するには、DisplayHeaderFooter を true に設定する必要があります。
            // - HeaderTemplate/FooterTemplate では、独自のページヘッダー/フッターを指定できます。
            var pdfOptions = new PdfOptions()
            {
                PageRanges = "2-5",
                PageWidth = 8.5f,
                PageHeight = 11f,
                Margins = new PdfMargins(0.2f, 1, 0.2f, 1),
                Landscape = true,
                DisplayHeaderFooter = true,
                HeaderTemplate = "<div style='-webkit-print-color-adjust:exact;background-color:#395daa;color:white;" +
                    "padding:0.1in;font-size:12em;width:1000px;margin-left:0.2in;margin-right:0.2in'>" +
                    "<span style='float:left'>Page <span class='pageNumber'></span> of <span class='totalPages'></span></span>" +
                    "<span style='float:right'>Document created on <span class='date'></span>" +
                    "</div>",
                FooterTemplate = "<div style='font-size:12em;width:1000px;margin-left:0.2in;margin-right:0.2in'>" +
                    $"<span>Document location: <span class='url'></span><img style='float:right;' width='40' height='40' src='{image}'></img></div>"
            };

            // HTML のレンダリングに使用する GcHtmlBrowser のインスタンスを生成します。
            using var browser = Common.Util.NewHtmlBrowser();
            browser.TimeoutOptions.MaxCloseTime = 10000;

            // ソース Web ページを一時ファイルにレンダリングします。
            using var htmlPage = browser.NewPage(uri);
            htmlPage.SaveAsPdf(tmp, pdfOptions);

            // 作成した PDF を一時ファイルからターゲットストリームにコピーします。
            using (var ts = File.OpenRead(tmp))
                ts.CopyTo(stream);
            // 一時ファイルを削除します。
            File.Delete(tmp);
            // PDF ドキュメントを保存します。
        }
    }
}