public class PDType3Font extends PDSimpleFont
encoding, glyphList
DEFAULT_FONT_MATRIX, dict
Constructor and Description |
---|
PDType3Font(COSDictionary fontDictionary)
Constructor.
|
PDType3Font(COSDictionary fontDictionary,
ResourceCache resourceCache)
Constructor.
|
Modifier and Type | Method and Description |
---|---|
protected byte[] |
encode(int unicode)
Encodes the given Unicode code point for use in a PDF content stream.
|
org.apache.fontbox.util.BoundingBox |
getBoundingBox()
Returns the font's bounding box.
|
PDType3CharProc |
getCharProc(int code)
Returns the stream of the glyph for the given character code
|
COSDictionary |
getCharProcs()
Returns the dictionary containing all streams to be used to render the glyphs.
|
Vector |
getDisplacement(int code)
Returns the displacement vector (w0, w1) in text space, for the given character.
|
PDRectangle |
getFontBBox()
This will get the fonts bounding box from its dictionary.
|
org.apache.fontbox.FontBoxFont |
getFontBoxFont()
Returns the embedded or system font used for rendering.
|
Matrix |
getFontMatrix()
Returns the font matrix, which represents the transformation from glyph space to text space.
|
float |
getHeight(int code)
Returns the height of the given character, in glyph space.
|
String |
getName()
Returns the name of this font, either the PostScript "BaseName" or the Type 3 "Name".
|
GeneralPath |
getPath(String name)
Returns the path for the character with the given name.
|
PDResources |
getResources()
Returns the optional resources of the type3 stream.
|
float |
getWidth(int code)
Returns the advance width of the given character, in glyph space.
|
float |
getWidthFromFont(int code)
Returns the width of a glyph in the embedded font file.
|
boolean |
hasGlyph(String name)
Returns true if the font contains the character with the given name.
|
boolean |
isDamaged()
Returns true if the embedded font file is damaged.
|
boolean |
isEmbedded()
Returns true if the font file is embedded in the PDF.
|
protected Boolean |
isFontSymbolic()
Internal implementation of isSymbolic, allowing for the fact that the result may be indeterminate.
|
boolean |
isStandard14()
Returns true if this font is one of the "Standard 14" fonts and receives special handling.
|
int |
readCode(InputStream in)
Reads a character code from a content stream string.
|
protected void |
readEncoding()
Reads the Encoding from the Font dictionary or the embedded or substituted font file.
|
protected Encoding |
readEncodingFromFont()
Called by readEncoding() if the encoding needs to be extracted from the font file.
|
addToSubset, getEncoding, getGlyphList, getStandard14Width, getSymbolicFlag, hasExplicitWidth, isNonZeroBoundingBox, isSymbolic, isVertical, subset, toUnicode, toUnicode, willBeSubset
encode, equals, getAverageFontWidth, getCOSObject, getFontDescriptor, getPositionVector, getSpaceWidth, getStandard14AFM, getStringWidth, getSubType, getToUnicodeCMap, getType, getWidths, hashCode, readCMap, setFontDescriptor, toString
public PDType3Font(COSDictionary fontDictionary) throws IOException
fontDictionary
- The font dictionary according to the PDF specification.IOException
- if the font could not be createdpublic PDType3Font(COSDictionary fontDictionary, ResourceCache resourceCache) throws IOException
fontDictionary
- The font dictionary according to the PDF specification.resourceCache
- Resource cache, can be null.IOException
- if the font could not be createdpublic String getName()
PDFontLike
protected final void readEncoding() throws IOException
PDSimpleFont
readEncoding
in class PDSimpleFont
IOException
- if the font file could not be readprotected Encoding readEncodingFromFont() throws IOException
PDSimpleFont
readEncodingFromFont
in class PDSimpleFont
IOException
- if the font file could not be read.protected Boolean isFontSymbolic()
PDSimpleFont
isFontSymbolic
in class PDSimpleFont
public GeneralPath getPath(String name) throws IOException
PDSimpleFont
getPath
in class PDSimpleFont
name
- glyph nameIOException
- if the path could not be readpublic boolean hasGlyph(String name) throws IOException
PDSimpleFont
hasGlyph
in class PDSimpleFont
name
- glyph nameIOException
- if the path could not be readpublic org.apache.fontbox.FontBoxFont getFontBoxFont()
PDSimpleFont
getFontBoxFont
in class PDSimpleFont
public Vector getDisplacement(int code) throws IOException
PDFont
getDisplacement
in class PDFont
code
- character codeIOException
- if the data could not be readpublic float getWidth(int code) throws IOException
PDFontLike
If you want the visual bounds of the glyph then call getPath(..) on the appropriate PDFont subclass to retrieve the glyph outline as a GeneralPath instead. See the cyan rectangles in the DrawPrintTextLocations.java example to see this in action.
getWidth
in interface PDFontLike
getWidth
in class PDFont
code
- character codeIOException
- if the width could not be readpublic float getWidthFromFont(int code) throws IOException
PDFontLike
code
- character codeIOException
- if the font could not be readpublic boolean isEmbedded()
public float getHeight(int code) throws IOException
PDFontLike
Warning: This method is deprecated in PDFBox 2.0 because there is no meaningful value which it can return. The
PDFontLike.getWidth(int)
method returns the advance width of a glyph, but there is no corresponding advance height.
The logical height of a character is the same for every character in a font, so if you want that, retrieve the
font bbox's height. Otherwise if you want the visual bounds of the glyph then call getPath(..) on the appropriate
PDFont subclass to retrieve the glyph outline as a GeneralPath. See the cyan rectangles in the
DrawPrintTextLocations.java example to see this in action.
code
- character codeIOException
- if the height could not be readprotected byte[] encode(int unicode) throws IOException
PDFont
This method is called when embedding text in PDFs and when filling in fields.
encode
in class PDFont
unicode
- Unicode code point.IOException
- If the text could not be encoded.public int readCode(InputStream in) throws IOException
PDFont
readCode
in class PDFont
in
- string streamIOException
- if the CMap or stream cannot be readpublic Matrix getFontMatrix()
PDFontLike
getFontMatrix
in interface PDFontLike
getFontMatrix
in class PDFont
public boolean isDamaged()
PDFontLike
public boolean isStandard14()
PDFont
isStandard14
in class PDSimpleFont
public PDResources getResources()
public PDRectangle getFontBBox()
public org.apache.fontbox.util.BoundingBox getBoundingBox()
PDFontLike
public COSDictionary getCharProcs()
public PDType3CharProc getCharProc(int code)
code
- character codeCopyright © 2002–2025 The Apache Software Foundation. All rights reserved.