HtmlSettings.vb
'' 完毕:
Imports System.IO
Imports System.Drawing
Imports GrapeCity.Documents.Pdf
Imports GrapeCity.Documents.Text
Imports GrapeCity.Documents.Html
'' 此示例演示如何呈现由 URL 指定的网页
'' PDF。这里我们渲染 WordIndex 示例的 C# 源代码。
'' 与HtmlRenderPage0类似,本示例直接使用GcHtmlRenderer,
'' 但展示了如何指定页面方向、边距等选项,
'' 页眉和页脚。
''
'' 作为参考,可以在以下标记扩展中使用
'' 标头和标题模板(本示例中使用了除标题之外的所有模板):
'' - <span class="date"> - 格式化日期
'' - <span class="title"> - 文档标题
'' - <span class="url"> - 文档位置
'' - <span class="pageNumber"> - 当前页码
'' - <span class="totalPages"> - 总页数
''
'' 请注意,在页眉/页脚中,图像不能指定为链接,
'' 但如本示例所示,支持 Base64 编码数据。
''
'' 另请注意,要在页眉/页脚中显示背景颜色,
'' 应指定以下 webkit CSS 扩展:
'' -webkit-打印颜色-调整:精确;
''
'' 请参阅HelloWorldHtml顶部评论中的注释
'' 有关将 GcDocs.Html 添加到项目的详细信息的示例代码。
Public Class HtmlSettings
Sub CreatePDF(ByVal stream As Stream)
'' 获取将在其中呈现网页的临时文件:
Dim tmp = Path.GetTempFileName()
'' 要呈现的网页的 Uri:
Dim uri = New Uri("https://developer.mescius.com/document-solutions/dot-net-pdf-api/demos/view-source-cs/word-index/")
'' 页脚模板中使用的图像:
Dim image = ""
'' 创建一个用于呈现 HTML 的 GcHtmlBrowser 实例:
Using browser = Util.NewHtmlBrowser()
'' PdfOptions 提供 HTML 到 PDF 转换的选项:
'' - PageRanges 允许您跳过在这种情况下为空的第一页。
'' - PageWidth/PageHeight 允许自定义页面大小(此处使用默认值进行演示)。
'' - 页边距指定页边距(默认为无边距)。
'' - 横向允许您更改页面方向。
'' - 缩放允许您放大或缩小渲染尺寸(默认值为 1)。
'' - 要添加自定义标头,需要将 DisplayHeaderFooter 设置为 true。
'' - HeaderTemplate/FooterTemplate 允许指定自定义页面标题。
Dim pdfOptions = New PdfOptions() With
{
.PageRanges = "2-100",
.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>"
}
'' 将源网页渲染到临时文件:
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)
'' 完毕:
End Sub
End Class