无法在iTextSharp XMLWorker中设置字体系列

时间:2013-10-23 22:22:00

标签: c# itextsharp

我正在尝试使用itextsharp XMLWorker库将一些HTML解析为PDF。它工作正常但我无法将一些Unicode字符(土耳其语)呈现到我的pdf中。

我已经阅读了几个关于这个问题的博客,他们都建议注册一个支持unicode字符的字体。然后在外部css文件中,我需要指定要使用的字体系列。

html
{
    font-family: 'Arial Unicode MS';
}

我也尝试了所有Arial作为家人。我也尝试在html中设置系列。

<body face = 'Arial'>

他们都没有工作。注册字体没有问题,外部CSS文件也正常工作。

这是我将HTML转换为PDF的方式,

string arialuniTff = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Fonts), "ARIALUNI.TTF");
FontFactory.Register(arialuniTff);

// Resolve CSS
var cssResolver = new StyleAttrCSSResolver();
var cssFile = XMLWorkerHelper.GetCSS(new FileStream(Server.MapPath("~/Content/Editor.css"), FileMode.Open));
cssResolver.AddCss(cssFile);

// HTML
CssAppliers ca = new CssAppliersImpl();
HtmlPipelineContext hpc = new HtmlPipelineContext(ca);
hpc.SetTagFactory(Tags.GetHtmlTagProcessorFactory());

// PIPELINES
PdfWriterPipeline pdf = new PdfWriterPipeline(document, writer);
HtmlPipeline htmlPipe = new HtmlPipeline(hpc, pdf);
CssResolverPipeline css = new CssResolverPipeline(cssResolver, htmlPipe);

XMLWorker worker = new XMLWorker(css, true);
XMLParser p = new XMLParser(worker);
StringReader sr = new StringReader("<html><head></head><body>" + topMessage.Replace("<br>", "<br></br>") + "</body></html>");
p.Parse(sr);

2 个答案:

答案 0 :(得分:0)

我看到您在不使用参数的情况下创建了CssAppliersImpl实例。如果你想处理字体,你应该创建一个'FontProvider'实现,并使用该实现的实例作为CssAppliersImpl构造函数的参数。例如:创建一个TestFontProvider类,显示解析HTML时需要哪些字体名称。这将有助于您了解是否注册了正确的字体。如果您看到所有必需的字体都已注册,则问题可能是由其他原因引起的。例如:可能使用错误的编码解析HTML ...

答案 1 :(得分:0)

这是经过多次尝试的有效解决方案:

 string fontPath = Path.Combine(@"fonts\Gaegu-Regular.ttf");
 var fontProvider = new XMLWorkerFontProvider(XMLWorkerFontProvider.DONTLOOKFORFONTS);
 fontProvider.Register(fontPath);            
 CssAppliers ca = new CssAppliersImpl(fontProvider);
 HtmlPipelineContext htmlContext = new HtmlPipelineContext(ca);
 var pipeline = new CssResolverPipeline(cssResolver, new HtmlPipeline(htmlContext, new PdfWriterPipeline(document, writer)));

谢谢。