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

'' このサンプルでは、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
    Sub CreatePDF(ByVal stream As Stream)
        '' Web ページがレンダリングされる一時ファイルを取得します。
        Dim tmp = Path.GetTempFileName()
        '' レンダリングする Web ページの Uri。
        Dim uri = New Uri("https://demo.mescius.jp/diodocs/pdf/view-source-cs/word-index/")
        '' フッターテンプレートで使用される画像。
        Dim image = ""

        '' HTML のレンダリングに使用する GcHtmlBrowser のインスタンスを生成します。
        Using browser = Util.NewHtmlBrowser()
            browser.TimeoutOptions.MaxCloseTime = 10000
            '' PdfOptions は、HTML から PDF への変換のオプションを設定するために使用されます。
            '' - PageRanges では、どのページを含めるかを指定します。
            '' - PageWidth/PageHeight では、ページサイズをカスタマイズできます(ここではデモのためデフォルトを使用しています)。
            '' - Margins では、ページの余白を指定します(デフォルトは余白なしです)。
            '' - Landscape では、ページの向きを変更することができます。
            '' - Scale では、レンダリングサイズを拡大または縮小できます(デフォルトは1)。
            '' - 独自のヘッダー/フッターを追加するには、DisplayHeaderFooter を true に設定する必要があります。
            '' - HeaderTemplate/FooterTemplate では、独自のページヘッダー/フッターを指定できます。
            Dim pdfOptions = New PdfOptions() With
            {
                .PageRanges = "2-5",
                .PageWidth = 8.5F,
                .PageHeight = 11.0F,
                .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>"
            }
            '' ソース Web ページを一時ファイルにレンダリングします。
            Using htmlPage = browser.NewPage(uri)
                htmlPage.SaveAsPdf(tmp, pdfOptions)
            End Using
        End Using
        '' 作成した PDF を一時ファイルからターゲットストリームにコピーします。
        Using ts = File.OpenRead(tmp)
            ts.CopyTo(stream)
        End Using
        '' 一時ファイルを削除します。
        File.Delete(tmp)
        '' PDF ドキュメントを保存します。
    End Sub
End Class