HtmlSettings.vb
'' 
'' このコードは、DioDocs for PDF のサンプルの一部として提供されています。
'' Copyright (c) GrapeCity 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 と同様に、このサンプルでは 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
    Sub CreatePDF(ByVal stream As Stream)
        '' Web ページがレンダリングされる一時ファイルを取得します。
        Dim tmp = Path.GetTempFileName()
        '' レンダリングする Web ページの Uri。
        Dim uri = New Uri("https://demo.grapecity.com/diodocs/pdf/view-source-cs/word-index/")
        '' フッターテンプレートで使用される画像。
        Dim image = ""

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