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