0

我在使用 iText XMLWorkerHelper 将 HTML 转换为 PDF 时遇到了麻烦。文档生成良好,但最终没有一些中欧字符(克罗地亚字母,如 č、ć、đ、ž)。

当我在没有 XMLWorkerHelper 的情况下编写文本并定义字体时,databese 中的相同文本被正确写入:

Dim fntArial As BaseFont = BaseFont.CreateFont("Helvetica", BaseFont.CP1250, BaseFont.NOT_EMBEDDED)
Dim fontText10 As Font = New Font(fntArial, 10)

但是当我使用 XMLWorkerHelper CE 时,字符会丢失。

Dim pdfDokument As New Document()
Dim docContent As String = "<style>" & _
                           "@font-face {font-family: 'Arial'; src: url('fonts/arial.ttf') format('truetype');}" & _
                           "body, td, div, span{font-family: 'Arial'; color: #253f60; font-size: 12px;}" & _
                           ...
                          "</style>" & _
                          "HTML content from database"
Dim wrtPDF As PdfWriter = PdfWriter.GetInstance(pdfDokument, New FileStream(Request.PhysicalApplicationPath & docName, FileMode.Create))
pdfDokument.Open()
Dim worker As XMLWorkerHelper = XMLWorkerHelper.GetInstance
worker.ParseXHtml(wrtPDF, pdfDokument, New StringReader(docContent))

如何将 CE 字体嵌入 PDF 文档并将其设置为 XMLWorkerHelper 的默认字体?

4

1 回答 1

3

我终于想出了如何提供我想要使用的字体。首先我指定了完整的字体路径,包括字体本身(如 c:/windows/fonts/arial.ttf)并且没有任何改变,然后我尝试了不同的编码,最终我只传递了解决我问题的字体文件夹的路径(在我阅读之后XMLWorkerFontProvider 类定义)。

克里斯谢谢你指出我正确的道路。

Dim worker = XMLWorkerHelper.GetInstance()
Dim htmlContent = new MemoryStream(Encoding.UTF8.GetBytes(docContent))
Dim css As memoryStream = new MemoryStream(System.Text.Encoding.UTF8.GetBytes(""))
worker.ParseXHtml(wrtPDF, pdfDokument, htmlContent, css, System.Text.Encoding.UTF8, new XMLWorkerFontProvider("c:/windows/fonts/"))
于 2016-02-03T07:50:14.190 回答