Использование iText 7 и Java при генерации PDF не может переносить длинные английские sh слова - PullRequest
0 голосов
/ 25 апреля 2020

Использование iText 7 и Java при генерировании PDF не позволяет переносить длинные слова Engi sh.

screenshot of pdf

Когда длинное слово в ячейка, слово не оборачивается внутри ячейки, скорее оно растет и содержимое таблицы отсутствует в PDF. Не знаю, как обернуть длинное слово в ячейку.

Я использую iText 7 для создания PDF.

Это мой Java файл:

package com.sid.pdf;

import java.io.File;
import com.itextpdf.kernel.pdf.PdfDocument;
import com.itextpdf.kernel.pdf.PdfWriter;
import com.itextpdf.layout.Document;
import com.itextpdf.layout.element.Cell;
import com.itextpdf.layout.element.Paragraph;
import com.itextpdf.layout.element.Table;
import com.itextpdf.layout.property.Property;
import com.itextpdf.layout.splitting.DefaultSplitCharacters;

public class TestTable {

    public static void main(String[] args) throws Exception

    {
        public static final String DEST = "C:\\test.pdf";
        File file = new File(DEST);
        file.getParentFile().mkdirs();
        new TestTable().manipulatePdf(DEST);
        System.out.println("PDF generated....");
    }

    protected void manipulatePdf(String dest) throws Exception {
        PdfDocument pdfDoc = new PdfDocument(new PdfWriter(dest));
        Document doc = new Document(pdfDoc);
        Table table = new Table(3);
        float tableWidth = doc.getPdfDocument().getDefaultPageSize().getWidth()
                - (doc.getLeftMargin() + doc.getRightMargin());
        table.setWidth(tableWidth);

        Cell cell1 = new Cell();
        Paragraph p = new Paragraph("1");
        p.setProperty(Property.SPLIT_CHARACTERS, new DefaultSplitCharacters());
        cell1.add(p);
        table.addCell(cell1);

        Cell cell2 = new Cell();
        Paragraph p2 = new Paragraph("CamLane_Disp_Warn_Rq_Pr2_e0h2tjvjx5d9y5cbvxqsnhwa7");
        p2.setProperty(Property.SPLIT_CHARACTERS, new DefaultSplitCharacters());
        cell2.add(p2);
        table.addCell(cell2);

        Cell cell3 = new Cell();
        Paragraph p3 = new Paragraph("CamLane_Disp_Warn_Rq_AR2");
        p3.setProperty(Property.SPLIT_CHARACTERS, new DefaultSplitCharacters());
        cell3.add(p3);
        table.addCell(cell3);

        Cell cell4 = new Cell();
        Paragraph p4 = new Paragraph("SQC/CRC");
        p4.setProperty(Property.SPLIT_CHARACTERS, new DefaultSplitCharacters());
        cell4.add(p4);
        table.addCell(cell4);

        Cell cell5 = new Cell();
        Paragraph p5 = new Paragraph("SPV_EngRq1_VAN_Pr2_vx0c4n6d46wgrav5gmco6bvc");
        p5.setProperty(Property.SPLIT_CHARACTERS, new DefaultSplitCharacters());
        cell5.add(p5);
        table.addCell(cell5);

        Cell cell6 = new Cell();
        Paragraph p6 = new Paragraph("Bckl_Sw_Ft_Stat_Pr2_b14xqvpzjykdbhltdyma53upe");
        p6.setProperty(Property.SPLIT_CHARACTERS, new DefaultSplitCharacters());
        cell6.add(p6);
        table.addCell(cell6);
        doc.add(table);
        doc.close();
    }
}

Ответы [ 2 ]

1 голос
/ 27 апреля 2020

Стратегия разделения по умолчанию заключается в поиске пробельных символов и других символов, на которые обычно разбивается текст (например, дефис -). В вашем случае слова не имеют таких символов. Вы уже сделали полшага к настройке разделенных символов для своего текста, определив свойство SPLIT_CHARACTERS, но недостающая часть выполняет пользовательскую реализацию ISplitCharacters. Пример реализации, который также допускает подчеркивание (_) в виде разделенных символов:

private static class CustomSplitCharacters extends DefaultSplitCharacters {
    @Override
    public boolean isSplitCharacter(GlyphLine text, int glyphPos) {
        if (!text.get(glyphPos).hasValidUnicode()) {
            return false;
        }
        boolean baseResult = super.isSplitCharacter(text, glyphPos);
        boolean myResult = false;
        Glyph glyph = text.get(glyphPos);
        if (glyph.getUnicode() == '_') {
            myResult = true;
        }
        return myResult || baseResult;
    }
}

Чтобы включить его, просто установите новый экземпляр вместо свойства по умолчанию для свойства SPLIT_CHARACTERS:

p6.setProperty(Property.SPLIT_CHARACTERS, new CustomSplitCharacters());

Визуальный результат:

result

0 голосов
/ 27 апреля 2020

Я пытался с приведенным ниже кодом и работал на меня. Я создал один пользовательский класс разделенных символов.

public class SpecificSplitCharacters extends DefaultSplitCharacters {
  @Override
  public boolean isSplitCharacter(GlyphLine text, int glyphPos) {
    if (!text.get(glyphPos).hasValidUnicode()) {
        return false;
    }
    Glyph glyph = text.get(glyphPos);
    if (glyph.getUnicode() == '_') {
        return true;
    } else {
        return super.isSplitCharacter(text, glyphPos);
    }
  }
}

Наконец, мы можем установить пользовательское свойство для объекта документа следующим образом:

doc.setProperty(Property.SPLIT_CHARACTERS, new SpecificSplitCharacters ());

(мы также можем установить свойство для каждого абзаца )

p6.setProperty(Property.SPLIT_CHARACTERS, new SpecificSplitCharacters ());
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...