C# 创建的PDF文件缺少土耳其语字符

C# 创建的PDF文件缺少土耳其语字符,c#,winforms,itext,C#,Winforms,Itext,嗯,我正在尝试将一些数据从WinForms应用程序导出到PDF文件。我下载了一些支持土耳其语字符的字体。在土耳其语中,有一些字母像ç,ğ,ş,ö,ü,ı。我的代码在显示ç、ö、ü方面没有问题,但不知何故,当用户输入ğ、ş或ı时,这些字母在PDF文件中表示为空白 我的代码如下: Document doc= new Document(iTextSharp.text.PageSize.LETTER, 10, 10, 42, 35); PdfWriter wri=PdfWriter.GetInstanc

嗯,我正在尝试将一些数据从WinForms应用程序导出到PDF文件。我下载了一些支持土耳其语字符的字体。在土耳其语中,有一些字母像ç,ğ,ş,ö,ü,ı。我的代码在显示ç、ö、ü方面没有问题,但不知何故,当用户输入ğ、ş或ı时,这些字母在PDF文件中表示为空白

我的代码如下:

Document doc= new Document(iTextSharp.text.PageSize.LETTER, 10, 10, 42, 35);
PdfWriter wri=PdfWriter.GetInstance(doc, new FileStream("Test.pdf", FileMode.Create));
doc.Open();

BaseFont bf = BaseFont.CreateFont(@"C:\aller.ttf", BaseFont.CP1252, BaseFont.EMBEDDED);
iTextSharp.text.Font font = new iTextSharp.text.Font(bf, 10, iTextSharp.text.Font.NORMAL);
Paragraph p1 = new Paragraph(new Chunk("çğşöüı", font));

doc.AddLanguage("tr-TR");
wri.SetLanguage("tr-TR");
doc.Add(p1);
doc.Close();

那么,我的错误在哪里呢?

经过努力,我找到了答案

BaseFont bF = BaseFont.CreateFont("C:\\windows\\fonts\\arial.ttf", "windows-1254", true);
 iTextSharp.text.Font f = new iTextSharp.text.Font(bF, 12f, iTextSharp.text.Font.NORMAL);
 Chunk c = new Chunk();
 c.Font = f;
 iTextSharp.text.Document document = new iTextSharp.text.Document();
 PdfWriter.GetInstance(document, new FileStream(@"C:\gorsel.pdf", FileMode.Create));
 string text = "küçük harf türkçe karakterler : ç ğ ı ö ş ü \n" +
 " BÜYÜK TÜRKÇE KARAKTERLER : Ç Ğ İ Ö Ş Ü";
 c.Append(text);
 document.Open();
 document.Add(new Paragraph(c));
 document.Close();

现在我可以使用PDF文件中的所有特殊字符。

您在
BaseFont.CP1252
中缺少的字符是吗?