Package com.aowagie.text.pdf
Class FontDetails
java.lang.Object
com.aowagie.text.pdf.FontDetails
Each font in the document will have an instance of this class
where the characters used will be represented.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final BaseFontThe fontprivate CJKFontThe font if it's an instance ofCJKFontprivate IntHashtableIntHashtable with CIDs of CJK glyphs that are used in the text.private final PdfNameThe font name that appears in the document body streamprivate final intThe font typeprivate final PdfIndirectReferenceThe indirect reference to this fontprivate HashMapThe map used with double byte encodings.private byte[]The array used with single byte encodingsprivate booleanIndicates if only a subset of the glyphs and widths for that particular encoding should be included in the document.private booleantrueif the font is symbolicprivate TrueTypeFontUnicodeThe font if it's an instance ofTrueTypeFontUnicode -
Constructor Summary
ConstructorsConstructorDescriptionFontDetails(PdfName fontName, PdfIndirectReference indirectReference, BaseFont baseFont) Each font used in a document has an instance of this class. -
Method Summary
Modifier and TypeMethodDescription(package private) byte[]convertToBytes(String text) Converts the text into bytes to be placed in the document.(package private) BaseFontGets theBaseFontof this font.(package private) PdfNameGets the font name as it appears in the document body.(package private) PdfIndirectReferenceGets the indirect reference to this font.booleanisSubset()Indicates if all the glyphs and widths for that particular encoding should be included in the document.voidsetSubset(boolean subset) Indicates if all the glyphs and widths for that particular encoding should be included in the document.(package private) voidWrites the font definition to the document.
-
Field Details
-
indirectReference
The indirect reference to this font -
fontName
The font name that appears in the document body stream -
baseFont
The font -
ttu
The font if it's an instance ofTrueTypeFontUnicode -
cjkFont
The font if it's an instance ofCJKFont -
shortTag
private byte[] shortTagThe array used with single byte encodings -
longTag
The map used with double byte encodings. The key is Integer(glyph) and the value is int[]{glyph, width, Unicode code} -
cjkTag
IntHashtable with CIDs of CJK glyphs that are used in the text. -
fontType
private final int fontTypeThe font type -
symbolic
private boolean symbolictrueif the font is symbolic -
subset
private boolean subsetIndicates if only a subset of the glyphs and widths for that particular encoding should be included in the document.
-
-
Constructor Details
-
FontDetails
FontDetails(PdfName fontName, PdfIndirectReference indirectReference, BaseFont baseFont) Each font used in a document has an instance of this class. This class stores the characters used in the document and other specifics unique to the current working document.- Parameters:
fontName- the font nameindirectReference- the indirect reference to the fontbaseFont- theBaseFont
-
-
Method Details
-
getIndirectReference
PdfIndirectReference getIndirectReference()Gets the indirect reference to this font.- Returns:
- the indirect reference to this font
-
getFontName
PdfName getFontName()Gets the font name as it appears in the document body.- Returns:
- the font name
-
getBaseFont
BaseFont getBaseFont()Gets theBaseFontof this font.- Returns:
- the
BaseFontof this font
-
convertToBytes
Converts the text into bytes to be placed in the document. The conversion is done according to the font and the encoding and the characters used are stored.- Parameters:
text- the text to convert- Returns:
- the conversion
-
writeFont
Writes the font definition to the document.- Parameters:
writer- thePdfWriterof this document
-
isSubset
public boolean isSubset()Indicates if all the glyphs and widths for that particular encoding should be included in the document.- Returns:
falseto include all the glyphs and widths.
-
setSubset
public void setSubset(boolean subset) Indicates if all the glyphs and widths for that particular encoding should be included in the document. Set tofalseto include all.- Parameters:
subset- new value of property subset
-