当前位置: 首页 > 知识库问答 >
问题:

IText-用中文字符生成PDF(简体中文)

房新翰
2023-03-14

我正在使用iText生成一些PDF,这些PDF有一些中文字符(简体中文-GB2312),但是我无法用这些字符生成PDF。

谁能告诉我哪里错了?

我尝试使用各种创作形式,但没有成功:

BaseFont bf = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED); 


com.itextpdf.text.DocumentException: Font 'STSong-Light' with 'UniGB-UCS2-H' is not recognized.
    at com.itextpdf.text.pdf.BaseFont.createFont(BaseFont.java:699)
    at com.itextpdf.text.pdf.BaseFont.createFont(BaseFont.java:606)
    at com.itextpdf.text.pdf.BaseFont.createFont(BaseFont.java:441)
    at com.ford.fc.frc.render.wsltopdf.PDFDefaultWriter.printText(PDFDefaultWriter.java:176)
    at com.ford.fc.frc.render.wsltopdf.PDFDefaultConverter.convertFile(PDFDefaultConverter.java:122)
    at com.ford.fc.frc.render.wsltopdf.PDFDefaultConverter.convert(PDFDefaultConverter.java:234)
    at com.ford.fc.frc.render.plugins.PDFDefaultRenderer.render(PDFDefaultRenderer.java:41)
    at com.ford.fc.frc.report.ReportManager.executeRenderer(ReportManager.java:1113)
    at com.ford.fc.frc.report.ReportManager.reportCompleted(ReportManager.java:596)
    at com.ford.fc.roc.ReportOutputControl.reportCompleted(ReportOutputControl.java:87)
    at LoadFRC.main(LoadFRC.java:69)



BaseFont bfComic = BaseFont.createFont(AsianFontMapper.ChineseSimplifiedFont,  AsianFontMapper.ChineseSimplifiedEncoding_H, BaseFont.NOT_EMBEDDED);
       Font fontbold = new Font(bfComic, 8);


 BaseFont bfComic = BaseFont.createFont("C:\\Windows\\Fonts\\cour.ttf",  BaseFont.IDENTITY_H, BaseFont.EMBEDDED);
       Font fontbold = new Font(bfComic, 8);

有人能帮我吗?

添加问题,这是我当前的测试代码:

while(null != (line = reader.readLine())) {
    document.open();

    FontSelector selector = new FontSelector();
    /*FontFactory.getFont("MSung-Light","UniCNS-UCS2-H", BaseFont.NOT_EMBEDDED);*/
    Font f2 = FontFactory.getFont(AsianFontMapper.ChineseSimplifiedFont, AsianFontMapper.ChineseTraditionalEncoding_H, BaseFont.NOT_EMBEDDED);
    f2.setColor(BaseColor.RED);
    selector.addFont(f2);
    Phrase ph = selector.process(line);
    document.add(new Paragraph(ph));


    BaseFont bfComic = BaseFont.createFont("C:\\Windows\\Fonts\\arialuni.ttf",  BaseFont.IDENTITY_V, BaseFont.EMBEDDED);
    Font fontbold = new Font(bfComic, 8);
    Paragraph p = new Paragraph(line, fontbold);
    document.add(p);

    // step 5: we close the document
}

共有2个答案

伍溪叠
2023-03-14

您的类路径中有iText jar,但是您忘记添加(正确的)iText-asian。罐子

下载extra jars ZIP文件的2.3版,该文件可在以下位置获得:http://sourceforge.net/projects/itext/files/extrajars/

这个罐子包含中国字形的度量。这样的字体永远不会被嵌入。在Adobe Reader中使用这种字体打开文档时,可能会要求您安装额外的字体包。

上官正志
2023-03-14

采用的解决方案是:

private static final String PATH_FONT_ARIALUNI = "C:\\Windows\\Fonts\\arialuni.ttf";
      private static final String PATH_FONT_COUR = "C:\\Windows\\Fonts\\cour.ttf";



       // FOR Chinese
       BaseFont baseFont = BaseFont.createFont(PATH_FONT_ARIALUNI, BaseFont.IDENTITY_H, BaseFont.EMBEDDED);
       Font font = new Font(baseFont, 6.8f);

       BaseFont baseFontNormal = BaseFont.createFont(PATH_FONT_COUR, BaseFont.IDENTITY_H, BaseFont.EMBEDDED);
       Font fontNormal = new Font(baseFontNormal, 6.8f);

       Paragraph par = new Paragraph();
       par.setLeading(9);

       char[] aa = line.toCharArray();
       boolean isLastChineseChar = false;

       System.out.println(line);

       StringBuilder newLine = new StringBuilder();
       for (int j = 0; j < line.length(); j++) {

           if((Character.UnicodeBlock.of(aa[j]) == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS)){
               if(!isLastChineseChar) {
                   par.add(new Phrase(newLine.toString(), fontNormal));
                   newLine.delete(0, newLine.length());
               }
               newLine.append(aa[j]);
               isLastChineseChar = true;
               /*System.out.println("Is CHINESE: " + aa[j]);*/
           } else {
               if(isLastChineseChar) {
                   par.add(new Phrase(newLine.toString(), font));
                   newLine.delete(0, newLine.length());
                   isLastChineseChar = false;
               }
               newLine.append(aa[j]);
               /*System.out.println("NOT IS CHINESE: " + aa[j]);*/
           }
       }

       if(isLastChineseChar){
           par.add(new Phrase(newLine.toString(), font));
       } else {
           par.add(new Phrase(newLine.toString(), fontNormal));
       }       

       if(line.contains(BREAK_PAGE)) {
          document.newPage();
       }

       par.setAlignment(Element.ALIGN_LEFT);
       document.add(par);
 类似资料:
  • 问题内容: 我正在使用iText生成一些PDF,这些pdf具有一些汉字(简体中文-GB2312),但是我无法使用这些字符生成pdf。 谁能告诉我我哪里错了? 我尝试使用各种形式的创作,但没有成功: 有人可以帮我吗? 添加问题,这是我当前的测试代码: 问题答案: 您的CLASSPATH中有iText jar,但是您忘记添加(正确的)itext-asian.jar。 请从此处下载额外的jar ZIP文

  • 问题内容: 我有一个使用Foxit表单设计器创建的pdf文件。在我的设计系统上,我安装了条形码字体。条形码字体在AcroField之一中使用。foxit似乎没有在文档中嵌入字体。 我也有一些客户的计算机上未安装条形码字体,因此我想将该字体嵌入到PDF中。我是否可以使用iText将AcroFields中使用的字体嵌入到PDF中? 编辑: 字体似乎包含在文本中,但没有包含在字段中,因此字体(条形码)将

  • 我可以修改现有PDF的字体吗。我有一些类型3(自定义)字体没有任何字体描述符。我想把它们换成一些有意义的字体。如何使用Itext或PDFBox执行此操作?

  • 所以我有下面的问题。我收到一个文件,其中包含一组字体。这些字体没有嵌入到文件中。下面是一个简单的例子: 我希望将这些字体嵌入到中,这样它们就可以自包含并且始终可用。但事情似乎没那么简单。我正在使用进行处理。 我已经阅读并尝试了以下问题/答案: null

  • 这段代码第一次可以运行得很好,但是当我第二次运行app时,它不会立即生成PDF文件。

  • 我正在使用library(v7.0.5.0)。我从。 生成PDF文件时,在其属性(Acrobat Reader 我可以看到有很多同名的重复字体。 如果我将文件从Acrobat Reader保存到“简化PDF文件”,所有重复的字体都将被清除,每个字体名称只保留一种字体。 我寻找一个解决方案,通过编程删除这些重复字体,因为这些重复字体会显著增加PDF文件的大小。使用Acrobat Reader压缩,文