Flying Sauser支持将html页面转换为pdf格式,但是对于页面中的中文则需要特殊进行处理。坊间流传已知的方法有2种。
1、在html页面中增加css样式,设定font-family属性。
在程序中加对应的代码处理,增加字体支持。
个人认为,此方法适用于页面较少,或者所有页面都有设置统一的font-family。
2、修改org.xhtmlrenderer.pdf.ITextOutputDevice类中的drawString方法代码。
将
替换为
此方法的好处是,修改之后方法一中的两步都不需要做了,可说是一劳永逸。
方法一比较麻烦,两边代码都要改,而且可能要修改很多页面,或者被迫改变整个项目的字体。
方法二虽然说解决了问题,但是个人认为仍然不太好。此种方法是在输出pdf文字时临时修改了字体(修改后_font是不会变的)。
通过查看源代码,发现程序会首先确认font family,如果页面设置,则取页面中的,否则取程序默认的CSSName.FONT_FAMILY(实际上就是serif)。然后,根据font family从org.xhtmlrenderer.pdf.ITextFontResolver对象中的_fontFamilies集合中取得字体,若集合中不存在对应的字体则再取默认(即Serif)。如此,我进行了如下修改:
1)修改org.xhtmlrenderer.css.constants.CSSName中的FONT_FAMILY属性为
2)修改org.xhtmlrenderer.pdf.ITextFontResolver中代码,
增加方法:
在方法createInitialFontMap中增加上面方法的调用:
这样,既保证了原有代码的结构,又可实现支持中文的功能。如有其它语言的需求,也可如此修改。
个人观点,仅供参考,如有转载,请注明出处。谢谢!
本文介绍两种解决HTML页面转换为PDF时中文显示问题的方法。一是通过增加CSS样式和程序代码支持特定字体;二是修改源代码以实现全局中文支持。
2111

被折叠的 条评论
为什么被折叠?



