Невозможно напечатать символы, связанные с математикой Unicode, используя Java - itextpdf - PullRequest
0 голосов
/ 29 ноября 2018

Я использую iText с Java и хочу напечатать больше или равно (≥), но он печатает пусто при проверке PDF.Шрифт:

public static final String FONT_A1L = "/opt/efact/ose/pdf/v1.0.0/conf/resources/fonts/ARIALUNI.TTF";

Ввод представляет собой строку, содержащую символ:

String text = "Item (≥110)";

или

String text = "Item (\u2265 110)";

Правильно сохраняется в переменной, включая символ ≥поэтому проблема возникает, когда она печатается в формате PDF.Я использую PdfTable:

PdfPTable documentDetail = new PdfPTable(1);
        documentDetail.setWidths(new float[] {800});
        documentDetail.setTotalWidth(800);
        documentDetail.setLockedWidth(true);

documentDetail.addCell(createPDFPCellBorder(true, true, true, false, BaseColor.LIGHT_GRAY, generalBaseColorFont, boldGrayFont10, Rectangle.BOTTOM, IPDFConstants.HEIGHT_FIXED, heightSize, new Integer[][]{ {IPDFConstants.PADDING_TOP,-2}, {IPDFConstants.PADDING_BOTTOM, 5}},
                text, com.itextpdf.text.Element.ALIGN_CENTER, com.itextpdf.text.Element.ALIGN_CENTER, com.itextpdf.text.Element.ALIGN_RIGHT, null));

documentDetail.writeSelectedRows(0, -1, 50, getHeight(50), canvas);         

Когда я запускаю программу и проверяю pdf, пишется следующее: Item (110)

Цвет создается как (Сам классвнизу поста):

BaseColor generalBaseColorFont = new BaseColor(new Color(173, 173, 173));

Как я могу напечатать такие символы?

Если это может быть полезно, вот код процедур, которые я использую (ясам не кодировал, это с работы):

protected PdfPCell createPDFPCellBorder(boolean lineOver, boolean lineUnder, boolean lineLeft, boolean lineRight, BaseColor backgroundColor, BaseColor borderColor, Font font, 
        int border, Integer heightType, Integer height, Integer paddingArray[][], String nameColumn, 
        Integer alignment, Integer horizontalAlignment, Integer verticalAlignment, Integer colsPan) throws Exception {

    PdfPCell cellCont = new PdfPCell();
    cellCont.setBorder(border);

    if (lineOver){
        cellCont.setBorderWidthTop(Float.valueOf(1));   
    }
    if (lineUnder){
        cellCont.setBorderWidthBottom(Float.valueOf(1));        
    }
    else{
        cellCont.setBorderWidthBottom(Float.valueOf(0));
    }
    if (lineLeft){
        cellCont.setBorderWidthLeft(Float.valueOf(1));
    }
    if (lineRight){
        cellCont.setBorderWidthRight(Float.valueOf(1));
    }
    if (null != backgroundColor)
    {
        cellCont.setBackgroundColor(backgroundColor);
    }
    if (null != borderColor)
    {
        cellCont.setBorderColor(borderColor);
    }       
    if (null != horizontalAlignment)
    {
        cellCont.setHorizontalAlignment(horizontalAlignment);
    }
    if (null != verticalAlignment)
    {
        cellCont.setVerticalAlignment(verticalAlignment);
    }
    if (null != colsPan)
    {
        cellCont.setColspan(colsPan);
    }

    if (null != paddingArray)
    {
        for (int i=0; i<paddingArray.length; i++)
        {
            switch (paddingArray[i][0]) 
            {
                case IPDFConstants.PADDING_RIGHT:
                    if (null != paddingArray[i][0])
                        cellCont.setPaddingRight(paddingArray[i][1]); break;
                case IPDFConstants.PADDING_LEFT:
                    if (null != paddingArray[i][0]) 
                        cellCont.setPaddingLeft(paddingArray[i][1]); break;
                case IPDFConstants.PADDING_BOTTOM:
                    if (null != paddingArray[i][0]) 
                        cellCont.setPaddingBottom(paddingArray[i][1]); break;
                case IPDFConstants.PADDING_TOP:
                    if (null != paddingArray[i][0]) 
                        cellCont.setPaddingTop(paddingArray[i][1]); break;
                case IPDFConstants.PADDING_ALL:
                    if (null != paddingArray[i][0]) 
                        cellCont.setPadding(paddingArray[i][1]); break;
                default:
                break;
            }
        }
    }

    if (null != heightType)
    {
        if (IPDFConstants.HEIGHT_FIXED == heightType) 
        {
            if(null != height) cellCont.setFixedHeight(height);
        } 
        else if (IPDFConstants.HEIGHT_MINIMUN == heightType) 
        {
            if(null != height) cellCont.setMinimumHeight(height);
        }
    }

    Paragraph paragraph = new Paragraph();
    paragraph.setFont(font);
    paragraph.add(nameColumn);
    if(null != alignment)
    {
        paragraph.setAlignment(alignment);
    }
    cellCont.addElement(paragraph);

    return cellCont;
}

public void addCell(PdfPCell cell) {
    rowCompleted = false;
    PdfPCell ncell = new PdfPCell(cell);

    int colspan = ncell.getColspan();
    colspan = Math.max(colspan, 1);
    colspan = Math.min(colspan, currentRow.length - currentRowIdx);
    ncell.setColspan(colspan);

    if (colspan != 1)
        isColspan = true;
    int rdir = ncell.getRunDirection();
    if (rdir == PdfWriter.RUN_DIRECTION_DEFAULT)
        ncell.setRunDirection(runDirection);

    skipColsWithRowspanAbove();

    boolean cellAdded = false;
    if (currentRowIdx < currentRow.length) {
        currentRow[currentRowIdx] = ncell;
        currentRowIdx += colspan;
        cellAdded = true;
    }

    skipColsWithRowspanAbove();

    while (currentRowIdx >= currentRow.length) {
        int numCols = getNumberOfColumns();
        if (runDirection == PdfWriter.RUN_DIRECTION_RTL) {
            PdfPCell rtlRow[] = new PdfPCell[numCols];
            int rev = currentRow.length;
            for (int k = 0; k < currentRow.length; ++k) {
                PdfPCell rcell = currentRow[k];
                int cspan = rcell.getColspan();
                rev -= cspan;
                rtlRow[rev] = rcell;
                k += cspan - 1;
            }
            currentRow = rtlRow;
        }
        PdfPRow row = new PdfPRow(currentRow);
        if (totalWidth > 0) {
            row.setWidths(absoluteWidths);
            totalHeight += row.getMaxHeights();
        }
        rows.add(row);
        currentRow = new PdfPCell[numCols];
        currentRowIdx = 0;
        skipColsWithRowspanAbove();
        rowCompleted = true;
    }

    if (!cellAdded) {
        currentRow[currentRowIdx] = ncell;
        currentRowIdx += colspan;
    }
}

public class BaseColor {
public static final BaseColor WHITE = new BaseColor(255, 255, 255);
public static final BaseColor LIGHT_GRAY = new BaseColor(192, 192, 192);
public static final BaseColor GRAY = new BaseColor(128, 128, 128);
public static final BaseColor DARK_GRAY = new BaseColor(64, 64, 64);
public static final BaseColor BLACK = new BaseColor(0, 0, 0);
public static final BaseColor RED = new BaseColor(255, 0, 0);
public static final BaseColor PINK = new BaseColor(255, 175, 175);
public static final BaseColor ORANGE = new BaseColor(255, 200, 0);
public static final BaseColor YELLOW = new BaseColor(255, 255, 0);
public static final BaseColor GREEN = new BaseColor(0, 255, 0);
public static final BaseColor MAGENTA = new BaseColor(255, 0, 255);
public static final BaseColor CYAN = new BaseColor(0, 255, 255);
public static final BaseColor BLUE = new BaseColor(0, 0, 255);
private static final double FACTOR = 0.7;
private int value;

public BaseColor(int red, int green, int blue, int alpha) {
    validate(red);
    validate(green);
    validate(blue);
    validate(alpha);
    value = ((alpha & 0xFF) << 24) | ((red & 0xFF) << 16) | ((green & 0xFF) << 8) | ((blue & 0xFF) << 0);
}

public BaseColor(int red, int green, int blue) {
    this(red, green, blue, 255);
}

public BaseColor(float red, float green, float blue, float alpha) {
    this((int)(red * 255 + .5), (int)(green * 255 + .5), (int)(blue * 255 + .5), (int)(alpha * 255 + .5));
}

public BaseColor(float red, float green, float blue) {
    this(red, green, blue, 1f);
}

public BaseColor(int argb) {
    value = argb;
}

public BaseColor(java.awt.Color color) {
    value = color.getRGB();
}

public int getRGB() {
    return value;
}

public int getRed() {
    return (getRGB() >> 16) & 0xFF;
}

public int getGreen() {
    return (getRGB() >> 8) & 0xFF;
}

public int getBlue() {
    return (getRGB() >> 0) & 0xFF;
}

public int getAlpha() {
    return (getRGB() >> 24) & 0xff;
}

public BaseColor brighter() {
    int r = getRed();
    int g = getGreen();
    int b = getBlue();

    int i = (int) (1.0 / (1.0 - FACTOR));
    if (r == 0 && g == 0 && b == 0) {
        return new BaseColor(i, i, i);
    }
    if (r > 0 && r < i)
        r = i;
    if (g > 0 && g < i)
        g = i;
    if (b > 0 && b < i)
        b = i;

    return new BaseColor(Math.min((int) (r / FACTOR), 255),
            Math.min((int) (g / FACTOR), 255),
            Math.min((int) (b / FACTOR), 255));
}

public BaseColor darker() {
    return new BaseColor(Math.max((int) (getRed() * FACTOR), 0),
            Math.max((int) (getGreen() * FACTOR), 0),
            Math.max((int) (getBlue() * FACTOR), 0));
}

public boolean equals(Object obj) {
    return obj instanceof BaseColor && ((BaseColor) obj).value == this.value;
}

public int hashCode() {
    return value;
}


private static void validate(int value) {
    if (value < 0 || value > 255)
        throw new IllegalArgumentException(MessageLocalization.getComposedMessage("color.value.outside.range.0.255"));
}

}

...