我遇到一些特殊的斯洛伐克人物(例如č,ň和ť)。它们在itextsharp生成的pdf中消失。
从我能够找到的,这个问题与我的BaseFont
的编码有关。目前我正在使用这个:
BaseFont.CreateFont(BaseFont.HELVETICA, iTextSharp.text.pdf.BaseFont.CP1250, BaseFont.NOT_EMBEDDED)
有人建议这应该有效:
BaseFont.CreateFont(BaseFont.HELVETICA, iTextSharp.text.pdf.BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED)
但它抛出了这个异常错误:
System.ArgumentException was caught
Message='Identity-H' is not a supported encoding name.
Parameter name: name
ParamName=name
Source=mscorlib
任何人都知道可能的原因和解决方法吗?
答案 0 :(得分:13)
问题在于:
BaseFont.CreateFont(BaseFont.HELVETICA ...
BaseFont.HELVETICA
是standard type 1 font,不能用于您的斯洛伐克字符。您需要使用具有正确字形的字体:
string FONT = "c:/windows/fonts/arialbd.ttf";
using (Document document = new Document()) {
PdfWriter.GetInstance(document, STREAM);
document.Open();
BaseFont bf = BaseFont.CreateFont(
FONT, BaseFont.IDENTITY_H, BaseFont.EMBEDDED
);
document.Add(new Paragraph("č, ň and ť", new Font(bf, 12)));
}