Class PDFont

    • Field Detail

      • DEFAULT_FONT_MATRIX

        protected static final Matrix DEFAULT_FONT_MATRIX
    • Method Detail

      • getStandard14AFM

        protected final FontMetrics getStandard14AFM()
        Returns the AFM if this is a Standard 14 font.
      • setFontDescriptor

        protected final void setFontDescriptor​(PDFontDescriptor fontDescriptor)
        Sets the font descriptor when embedding a font.
      • readCMap

        protected final CMap readCMap​(COSBase base)
                               throws IOException
        Reads a CMap given a COS Stream or Name. May return null if a predefined CMap does not exist.
        Parameters:
        base - COSName or COSStream
        Throws:
        IOException
      • getCOSObject

        public COSDictionary getCOSObject()
        Description copied from interface: COSObjectable
        Convert this standard java object to a COS object.
        Specified by:
        getCOSObject in interface COSObjectable
        Returns:
        The cos object that matches this Java object.
      • getPositionVector

        public Vector getPositionVector​(int code)
        Description copied from interface: PDFontLike
        Returns the position vector (v), in text space, for the given character. This represents the position of vertical origin relative to horizontal origin, for horizontal writing it will always be (0, 0). For vertical writing both x and y are set.
        Specified by:
        getPositionVector in interface PDFontLike
        Parameters:
        code - character code
        Returns:
        position vector
      • getDisplacement

        public Vector getDisplacement​(int code)
                               throws IOException
        Returns the displacement vector (w0, w1) in text space, for the given character. For horizontal text only the x component is used, for vertical text only the y component.
        Parameters:
        code - character code
        Returns:
        displacement vector
        Throws:
        IOException
      • getWidth

        public float getWidth​(int code)
                       throws IOException
        Description copied from interface: PDFontLike
        Returns the advance width of the given character, in glyph space.
        Specified by:
        getWidth in interface PDFontLike
        Parameters:
        code - character code
        Throws:
        IOException
      • getStandard14Width

        protected abstract float getStandard14Width​(int code)
        Returns the glyph width from the AFM if this is a Standard 14 font.
        Parameters:
        code - character code
        Returns:
        width in 1/1000 text space
      • getWidthFromFont

        public abstract float getWidthFromFont​(int code)
                                        throws IOException
        Description copied from interface: PDFontLike
        Returns the width of a glyph in the embedded font file.
        Specified by:
        getWidthFromFont in interface PDFontLike
        Parameters:
        code - character code
        Returns:
        width in glyph space
        Throws:
        IOException - if the font could not be read
      • isEmbedded

        public abstract boolean isEmbedded()
        Description copied from interface: PDFontLike
        Returns true if the font file is embedded in the PDF.
        Specified by:
        isEmbedded in interface PDFontLike
      • getHeight

        public abstract float getHeight​(int code)
                                 throws IOException
        Description copied from interface: PDFontLike
        Returns the height of the given character, in glyph space. This can be expensive to calculate. Results are only approximate.
        Specified by:
        getHeight in interface PDFontLike
        Parameters:
        code - character code
        Throws:
        IOException
      • encode

        public final byte[] encode​(String text)
                            throws IOException
        Encodes the given string for use in a PDF content stream.
        Parameters:
        text - Any Unicode text.
        Returns:
        Array of PDF content stream bytes.
        Throws:
        IOException - If the text could not be encoded.
      • encode

        protected abstract byte[] encode​(int unicode)
                                  throws IOException
        Encodes the given Unicode code point for use in a PDF content stream. Content streams use a multi-byte encoding with 1 to 4 bytes.

        This method is called when embedding text in PDFs and when filling in fields.

        Parameters:
        unicode - Unicode code point.
        Returns:
        Array of 1 to 4 PDF content stream bytes.
        Throws:
        IOException - If the text could not be encoded.
      • getStringWidth

        public float getStringWidth​(String text)
                             throws IOException
        Returns the width of the given Unicode string.
        Parameters:
        text - The text to get the width of.
        Returns:
        The width of the string in 1/1000 units of text space
        Throws:
        IOException - If there is an error getting the width information.
      • getAverageFontWidth

        public float getAverageFontWidth()
        This will get the average font width for all characters.
        Specified by:
        getAverageFontWidth in interface PDFontLike
        Returns:
        The width is in 1000 unit of text space, ie 333 or 777
      • readCode

        public abstract int readCode​(InputStream in)
                              throws IOException
        Reads a character code from a content stream string. Codes may be up to 4 bytes long.
        Parameters:
        in - string stream
        Returns:
        character code
        Throws:
        IOException - if the CMap or stream cannot be read
      • toUnicode

        public String toUnicode​(int code,
                                GlyphList customGlyphList)
                         throws IOException
        Returns the Unicode character sequence which corresponds to the given character code.
        Parameters:
        code - character code
        customGlyphList - a custom glyph list to use instead of the Adobe Glyph List
        Returns:
        Unicode character(s)
        Throws:
        IOException
      • toUnicode

        public String toUnicode​(int code)
                         throws IOException
        Returns the Unicode character sequence which corresponds to the given character code.
        Parameters:
        code - character code
        Returns:
        Unicode character(s)
        Throws:
        IOException
      • getType

        public String getType()
        This will always return "Font" for fonts.
        Returns:
        The type of object that this is.
      • getSubType

        public String getSubType()
        This will get the subtype of font.
      • getName

        public abstract String getName()
        Description copied from interface: PDFontLike
        Returns the name of this font, either the PostScript "BaseName" or the Type 3 "Name".
        Specified by:
        getName in interface PDFontLike
      • getWidths

        protected final List<Integer> getWidths()
        The widths of the characters. This will be null for the standard 14 fonts.
        Returns:
        The widths of the characters.
      • getFontMatrix

        public Matrix getFontMatrix()
        Description copied from interface: PDFontLike
        Returns the font matrix, which represents the transformation from glyph space to text space.
        Specified by:
        getFontMatrix in interface PDFontLike
      • getSpaceWidth

        public float getSpaceWidth()
        Determines the width of the space character.
        Returns:
        the width of the space character
      • isVertical

        public abstract boolean isVertical()
        Returns true if the font uses vertical writing mode.
      • isStandard14

        public boolean isStandard14()
        Returns true if this font is one of the "Standard 14" fonts and receives special handling.
      • addToSubset

        public abstract void addToSubset​(int codePoint)
        Adds the given Unicode point to the subset.
        Parameters:
        codePoint - Unicode code point
      • subset

        public abstract void subset()
                             throws IOException
        Replaces this font with a subset containing only the given Unicode characters.
        Throws:
        IOException - if the subset could not be written
      • willBeSubset

        public abstract boolean willBeSubset()
        Returns true if this font will be subset when embedded.
      • isDamaged

        public abstract boolean isDamaged()
        Description copied from interface: PDFontLike
        Returns true if the embedded font file is damaged.
        Specified by:
        isDamaged in interface PDFontLike
      • hashCode

        public int hashCode()
        Overrides:
        hashCode in class Object