自定义字体在使用 WKHTMLTOPDF 库生成的 PDF 中不起作用

Qaz*_*azi 5 css truetype wkhtmltopdf laravel laravel-5.1

我正在使用 Laravel 5.1 SnappyPDF 包装器,它正在使用WKHTMLTOPDF库。我正在尝试为我的 PDF 文件包含一些自定义的谷歌字体,但这些字体在生成的 PDF 文件中不起作用。

我尝试过,将字体转换为Base64并尝试通过绝对 URL 和相对 URL 包含字体,还尝试了许多在堆栈溢出时可用的答案,但没有一个对我有用。如何解决这个问题。

//Calling fonts
@font-face {
    font-family: Roboto Condensed;
    src: url("/fonts/RobotoCondensed-Regular/RobotoCondensed-Regular.ttf");
}
@font-face {
    font-family: 'Open Sans';src: url("/fonts/OpenSans/OpenSans-Regular.ttf");
}

@font-face {
    font-family: 'Open Sans Semi Bold Italic';
    src: url("/fonts/OpenSans/OpenSans-SemiboldItalic.ttf");
}

 //implenting fonts
.report-page2-col-wrapper .col-heading{
    font-family:"Open Sans Semi Bold Italic";
    font-size:12pt;
    line-height:17pt;
}
Run Code Online (Sandbox Code Playgroud)

查看屏幕截图的差异

1) 这是网页浏览器的 HTML 版本,看起来查找和字体实现正确


在此处输入图片说明

2) 这是生成的 PDF 版本,字体应用不正确


在此处输入图片说明

Add*_*Ltd 6

有多种解决方案可以实现这一点:

1)如果您使用 google 字体,请尝试以下操作:<link>用于包含 google 字体

<link href='http://fonts.googleapis.com/css?family=YOURFONTFAMILY' rel='stylesheet' type='text/css'>
Run Code Online (Sandbox Code Playgroud)

使用<style>应用字体效果

<style type = "text/css">
    p { font-family: 'YOURFONTFAMILY'; }
</style>
Run Code Online (Sandbox Code Playgroud)

2)使用Base64编码工具对字体进行编码并在css中使用

@font-face {
    font-family: 'YOURFONTFAMILY';
    src: url(data:font/truetype;charset=utf-8;base64,AAEAAAATAQA...
}
Run Code Online (Sandbox Code Playgroud)

希望以上之一是您的解决方案!

参考:使用 wkhtmltopdf 的自定义字体helvetica 字体在 wkhtmltopdf 中不起作用

  • 如果您不使用 Google 字体怎么办?Base64 方法对我不起作用。 (3认同)