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

            // ソース Uri で GcHtmlRendererを作成します(GcHtmlRenderer ctor および
            // 他の HTML レンダリングメソッドは、レンダリングする HTML ページを指定する Uri、
            // または実際の HTML を表す文字列のいずれかを受け入れることに注意してください)。
            using (var re = new GcHtmlRenderer(uri))
            {
                // PdfSettings では、HTML から PDF への変換のオプションを提供できます。
                // - PageRanges では、この場合は空の最初のページをスキップできます。
                // - PageWidth/PageHeight では、ページサイズをカスタマイズできます(ここではデフォルトでデモに使用されます)。
                // - マージンはページのマージンを指定します(デフォルトはマージンなしです)。
                // - IgnoreCSSPageSize は、ここで指定されたページサイズが使用されるようにします。
                // - 横向きでは、ページの向きを変更できます。
                // - スケールを使用すると、レンダリングサイズを拡大または縮小できます(デフォルトは1)。
                // - カスタムヘッダーを追加するには、DisplayHeaderFooter を true に設定する必要があります。
                // - HeaderTemplate/FooterTemplate では、カスタムページヘッダーを指定できます。
                var pdfSettings = new PdfSettings()
                {
                    PageRanges = "2-100",
                    PageWidth = 8.5f,
                    PageHeight = 11f,
                    Margins = new Margins(0.2f, 1, 0.2f, 1),
                    IgnoreCSSPageSize = true,
                    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>"
                };
                // ソース Web ページを一時ファイルにレンダリングします。
                re.RenderToPdf(tmp, pdfSettings);
            }
            // 作成した PDF を一時ファイルからターゲットストリームにコピーします。
            using (var ts = File.OpenRead(tmp))
                ts.CopyTo(stream);
            // 一時ファイルを削除します。
            File.Delete(tmp);
            // PDF ドキュメントを保存します。
        }
    }
}