Class DocumentFont
java.lang.Object
com.gitlab.pdftk_java.com.lowagie.text.pdf.BaseFont
com.gitlab.pdftk_java.com.lowagie.text.pdf.DocumentFont
-
Nested Class Summary
Nested classes/interfaces inherited from class BaseFont
BaseFont.StreamFont -
Field Summary
FieldsModifier and TypeFieldDescription(package private) float(package private) float(package private) String[](package private) BaseFont(package private) String[](package private) float(package private) PdfDictionary(package private) String(package private) float(package private) float(package private) float(package private) PRIndirectReference(package private) static final int[](package private) IntHashtable(package private) float(package private) floatFields inherited from class BaseFont
ASCENT, AWT_ASCENT, AWT_DESCENT, AWT_LEADING, AWT_MAXADVANCE, BBOXLLX, BBOXLLY, BBOXURX, BBOXURY, BuiltinFonts14, CACHED, CAPHEIGHT, charBBoxes, CID_NEWLINE, COURIER, COURIER_BOLD, COURIER_BOLDOBLIQUE, COURIER_OBLIQUE, CP1250, CP1252, CP1257, DESCENT, differences, directTextToByte, embedded, EMBEDDED, encoding, fastWinansi, FONT_TYPE_CJK, FONT_TYPE_DOCUMENT, FONT_TYPE_T1, FONT_TYPE_T3, FONT_TYPE_TT, FONT_TYPE_TTUNI, fontCache, fontSpecific, fontType, forceWidthsOutput, HELVETICA, HELVETICA_BOLD, HELVETICA_BOLDOBLIQUE, HELVETICA_OBLIQUE, IDENTITY_H, IDENTITY_V, ITALICANGLE, MACROMAN, NOT_CACHED, NOT_EMBEDDED, notdef, RESOURCE_PATH, subset, SYMBOL, TIMES_BOLD, TIMES_BOLDITALIC, TIMES_ITALIC, TIMES_ROMAN, unicodeDifferences, widths, WINANSI, ZAPFDINGBATS -
Constructor Summary
ConstructorsConstructorDescriptionDocumentFont(PRIndirectReference refFont) Creates a new instance of DocumentFont -
Method Summary
Modifier and TypeMethodDescriptionbooleancharExists(char c) Checks if a character exists in this font.(package private) byte[]convertToBytes(String text) Converts aStringto a byte array according to the font's encoding.void(package private) voidfillEncoding(PdfName encoding) (package private) voidint[]getCharBBox(char c) Gets the smallest box enclosing the character contours.String[][]Gets the family name of the font.floatgetFontDescriptor(int key, float fontSize) Gets the font parameter identified bykey.String[][]Gets the full name of the font.(package private) PdfIndirectReferenceintgetKerning(char char1, char char2) Gets the kerning between two Unicode chars.Gets the postscript font name.protected int[]getRawCharBBox(int c, String name) (package private) intgetRawWidth(int c, String name) Gets the width from the font according to the Unicode charcor thename.intGets the width of aStringin normalized 1000 units.booleanChecks if the font has any kerning pairs.booleansetKerning(char char1, char char2, int kern) Sets the kerning between two Unicode chars.voidsetPostscriptFontName(String name) Sets the font name that will appear in the pdf font dictionary.(package private) voidwriteFont(PdfWriter writer, PdfIndirectReference ref, Object[] params) Outputs to the writer the font dictionaries and streams.Methods inherited from class BaseFont
correctArabicAdvance, createEncoding, createFont, createFont, createFont, createSubsetPrefix, enumerateTTCNames, enumerateTTCNames, getAllFontNames, getAscent, getAscentPoint, getBaseName, getCidCode, getCodePagesSupported, getDescent, getDescentPoint, getDifferences, getDocumentFonts, getDocumentFonts, getEncoding, getFontType, getFullFontName, getResourceStream, getResourceStream, getUnicodeDifferences, getUnicodeDifferences, getUnicodeEquivalent, getWidth, getWidthPoint, getWidthPoint, getWidthPointKerned, getWidths, isDirectTextToByte, isEmbedded, isFontSpecific, isForceWidthsOutput, isSubset, normalizeEncoding, setCharAdvance, setDirectTextToByte, setForceWidthsOutput, setSubset
-
Field Details
-
fontName
String fontName -
refFont
PRIndirectReference refFont -
font
PdfDictionary font -
uni2byte
IntHashtable uni2byte -
Ascender
float Ascender -
CapHeight
float CapHeight -
Descender
float Descender -
ItalicAngle
float ItalicAngle -
llx
float llx -
lly
float lly -
urx
float urx -
ury
float ury -
cjkMirror
BaseFont cjkMirror -
cjkNames
String[] cjkNames -
cjkEncs
String[] cjkEncs -
stdEnc
static final int[] stdEnc
-
-
Constructor Details
-
DocumentFont
DocumentFont(PRIndirectReference refFont) Creates a new instance of DocumentFont
-
-
Method Details
-
doType1TT
public void doType1TT() -
fillFontDesc
void fillFontDesc() -
fillEncoding
-
getFamilyFontName
Gets the family name of the font. If it is a True Type font each array element will have {Platform ID, Platform Encoding ID, Language ID, font name}. The interpretation of this values can be found in the Open Type specification, chapter 2, in the 'name' table.
For the other fonts the array has a single element with {"", "", "", font name}.- Specified by:
getFamilyFontNamein classBaseFont- Returns:
- the family name of the font
-
getFontDescriptor
public float getFontDescriptor(int key, float fontSize) Gets the font parameter identified bykey. Valid values forkeyareASCENT,CAPHEIGHT,DESCENT,ITALICANGLE,BBOXLLX,BBOXLLY,BBOXURXandBBOXURY.- Specified by:
getFontDescriptorin classBaseFont- Parameters:
key- the parameter to be extractedfontSize- the font size in points- Returns:
- the parameter in points
-
getFullFontName
Gets the full name of the font. If it is a True Type font each array element will have {Platform ID, Platform Encoding ID, Language ID, font name}. The interpretation of this values can be found in the Open Type specification, chapter 2, in the 'name' table.
For the other fonts the array has a single element with {"", "", "", font name}.- Specified by:
getFullFontNamein classBaseFont- Returns:
- the full name of the font
-
getKerning
public int getKerning(char char1, char char2) Gets the kerning between two Unicode chars.- Specified by:
getKerningin classBaseFont- Parameters:
char1- the first charchar2- the second char- Returns:
- the kerning to be applied
-
getPostscriptFontName
Gets the postscript font name.- Specified by:
getPostscriptFontNamein classBaseFont- Returns:
- the postscript font name
-
getRawWidth
Gets the width from the font according to the Unicode charcor thename. If thenameis null it's a symbolic font.- Specified by:
getRawWidthin classBaseFont- Parameters:
c- the unicode charname- the glyph name- Returns:
- the width of the char
-
hasKernPairs
public boolean hasKernPairs()Checks if the font has any kerning pairs.- Specified by:
hasKernPairsin classBaseFont- Returns:
trueif the font has any kerning pairs
-
writeFont
void writeFont(PdfWriter writer, PdfIndirectReference ref, Object[] params) throws DocumentException, IOException Outputs to the writer the font dictionaries and streams.- Specified by:
writeFontin classBaseFont- Parameters:
writer- the writer for this documentref- the font indirect referenceparams- several parameters that depend on the font type- Throws:
IOException- on errorDocumentException- error in generating the object
-
getWidth
-
convertToBytes
Description copied from class:BaseFontConverts aStringto a byte array according to the font's encoding.- Overrides:
convertToBytesin classBaseFont- Parameters:
text- theStringto be converted- Returns:
- an array of
byterepresenting the conversion according to the font's encoding
-
getIndirectReference
PdfIndirectReference getIndirectReference() -
charExists
public boolean charExists(char c) Description copied from class:BaseFontChecks if a character exists in this font.- Overrides:
charExistsin classBaseFont- Parameters:
c- the character to check- Returns:
trueif the character has a glyph,falseotherwise
-
setPostscriptFontName
Sets the font name that will appear in the pdf font dictionary. It does nothing in this case as the font is already in the document.- Specified by:
setPostscriptFontNamein classBaseFont- Parameters:
name- the new font name
-
setKerning
public boolean setKerning(char char1, char char2, int kern) Description copied from class:BaseFontSets the kerning between two Unicode chars.- Specified by:
setKerningin classBaseFont- Parameters:
char1- the first charchar2- the second charkern- the kerning to apply in normalized 1000 units- Returns:
trueif the kerning was applied,falseotherwise
-
getCharBBox
public int[] getCharBBox(char c) Description copied from class:BaseFontGets the smallest box enclosing the character contours. It will returnnullif the font has not the information or the character has no contours, as in the case of the space, for example. Characters with no contours may also return [0,0,0,0].- Overrides:
getCharBBoxin classBaseFont- Parameters:
c- the character to get the contour bounding box from- Returns:
- an array of four floats with the bounding box in the format [llx,lly,urx,ury] or
null
-
getRawCharBBox
- Specified by:
getRawCharBBoxin classBaseFont
-