如何在 PDF 中设置字体
网页字体是专为网站使用而设计的字体。 这些字体托管在网络服务器上,并由网页浏览器下载,以确保网站上的文本呈现一致且视觉上吸引人,不受用户本地字体可用性的影响。 此外,图标字体使用符号和字形,常用于网页设计中,以创建可缩放、可自定义的图标,并通过CSS操作保持视觉上的一致性用户界面。
CSS包括网络字体,允许您指定在访问您的网站时下载的字体文件。 IronPDF支持从HTML加载字体并渲染到PDF。
如何在 PDF 中设置字体
- 下载用于在 PDF 中设置字体的 C# 库
- 利用 HTML 从外部来源导入或请求字体
- 延迟渲染过程,确保正确加载字体
- 像往常一样将 HTML 转换为 PDF
- 在 CSS 样式中使用 @font-face 规则导入字体文件
开始在您的项目中使用IronPDF,并立即获取免费试用。
查看 IronPDF 上 Nuget 用于快速安装和部署。它有超过800万次下载,正在使用C#改变PDF。
Install-Package IronPdf
考虑安装 IronPDF DLL 直接。下载并手动安装到您的项目或GAC表单中: IronPdf.zip
手动安装到你的项目中
下载DLL使用 WebFonts 和图标示例
IronPDF 支持网络字体 (如 Google 字体和 Adobe 网页字体应用程序接口)和图标字体,例如 Bootstrap 和字体真棒.
字体在渲染时常常需要一定的延迟以正确加载。 当字体未正确加载时,可能会导致页面上没有任何文本的空白页。 您可以使用 WaitFor.AllFontsLoaded
方法来等待字体加载,通过为其分配最大等待时间。 默认的最大等待时间为500毫秒。
这是一个如何使用的小示例WebFont命名为 "龙虾"。
:path=/static-assets/pdf/content-code-examples/how-to/webfonts-webicons-render-webfont.cs
using IronPdf;
// HTML contains webfont
var html = @"<link href=""https://fonts.googleapis.com/css?family=Lobster"" rel=""stylesheet"">
<p style=""font-family: 'Lobster', serif; font-size:30px;"" > Hello Google Fonts</p>";
ChromePdfRenderer renderer = new ChromePdfRenderer();
// Wait for font to load
renderer.RenderingOptions.WaitFor.AllFontsLoaded(2000);
// Render HTML to PDF
PdfDocument pdf = renderer.RenderHtmlAsPdf(html);
// Export the PDF
pdf.SaveAs("font-test.pdf");
Imports IronPdf
' HTML contains webfont
Private html = "<link href=""https://fonts.googleapis.com/css?family=Lobster"" rel=""stylesheet"">
<p style=""font-family: 'Lobster', serif; font-size:30px;"" > Hello Google Fonts</p>"
Private renderer As New ChromePdfRenderer()
' Wait for font to load
renderer.RenderingOptions.WaitFor.AllFontsLoaded(2000)
' Render HTML to PDF
Dim pdf As PdfDocument = renderer.RenderHtmlAsPdf(html)
' Export the PDF
pdf.SaveAs("font-test.pdf")
探索更多 WaitFor 选项,如字体、JavaScript、HTML 元素和网络空闲的 WaitFor 选项,请访问 "WaitFor"。如何使用 WaitFor 类延迟 C# PDF 渲染.'
导入字体文件示例
要使用现有的字体文件,请应用@font-faceCSS样式中的规则。 它也适用于使用 @font-face 规则和嵌入 base64 编码的 woff 文件的组合。 在下面的例子中,我将使用Pixelify Sans 字体.
:path=/static-assets/pdf/content-code-examples/how-to/webfonts-webicons-custom-font.cs
using IronPdf;
// Import custom font
string html = @"<!DOCTYPE html>
<html>
<head>
<style>
@font-face {font-family: 'Pixelify';
src: url('fonts\PixelifySans-VariableFont_wght.ttf');
}
p {
font-family: 'Pixelify';
font-size: 70px;
}
</style>
</head>
<body>
<p>Custom font</p>
</body>
</html>";
ChromePdfRenderer renderer = new ChromePdfRenderer();
// Render HTML to PDF
PdfDocument pdf = renderer.RenderHtmlAsPdf(html);
// Export the PDF
pdf.SaveAs("customFont.pdf");
Imports IronPdf
' Import custom font
Private html As String = "<!DOCTYPE html>
<html>
<head>
<style>
@font-face {font-family: 'Pixelify';
src: url('fonts\PixelifySans-VariableFont_wght.ttf');
}
p {
font-family: 'Pixelify';
font-size: 70px;
}
</style>
</head>
<body>
<p>Custom font</p>
</body>
</html>"
Private renderer As New ChromePdfRenderer()
' Render HTML to PDF
Private pdf As PdfDocument = renderer.RenderHtmlAsPdf(html)
' Export the PDF
pdf.SaveAs("customFont.pdf")
限制在Azure PDF上
"(《世界人权宣言》)Azure 托管平台不支持服务器在其较低的共享Web应用层中加载SVG字体。 然而,Azure的VPS和Web Role没有以相同方式进行沙盒处理,且支持网页字体渲染。