Package com.itextpdf.text.pdf
Class TrueTypeFontUnicode
java.lang.Object
com.itextpdf.text.pdf.BaseFont
com.itextpdf.text.pdf.TrueTypeFont
com.itextpdf.text.pdf.TrueTypeFontUnicode
- All Implemented Interfaces:
Comparator<int[]>
Represents a True Type font with Unicode encoding. All the character
in the font can be used directly by using the encoding Identity-H or
Identity-V. This is the only way to represent some character sets such
as Thai.
-
Nested Class Summary
Nested classes/interfaces inherited from class com.itextpdf.text.pdf.TrueTypeFont
TrueTypeFont.FontHeader, TrueTypeFont.HorizontalHeader, TrueTypeFont.WindowsMetricsNested classes/interfaces inherited from class com.itextpdf.text.pdf.BaseFont
BaseFont.StreamFont -
Field Summary
FieldsFields inherited from class com.itextpdf.text.pdf.TrueTypeFont
allNameEntries, bboxes, cff, cffLength, cffOffset, cmap10, cmap31, cmapExt, codePages, directoryOffset, familyName, fileName, fontName, fullName, glyphIdToChar, glyphWidthsByIndex, head, hhea, isFixedPitch, italicAngle, justNames, kerning, maxGlyphId, os_2, rf, style, subFamily, tables, ttcIndex, underlinePosition, underlineThicknessFields inherited from class com.itextpdf.text.pdf.BaseFont
ASCENT, AWT_ASCENT, AWT_DESCENT, AWT_LEADING, AWT_MAXADVANCE, BBOXLLX, BBOXLLY, BBOXURX, BBOXURY, BuiltinFonts14, CACHED, CAPHEIGHT, CHAR_RANGE_ARABIC, CHAR_RANGE_CYRILLIC, CHAR_RANGE_HEBREW, CHAR_RANGE_LATIN, charBBoxes, CID_NEWLINE, compressionLevel, COURIER, COURIER_BOLD, COURIER_BOLDOBLIQUE, COURIER_OBLIQUE, CP1250, CP1252, CP1257, DEFAULT_FONT_MATRIX, 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, FONT_WEIGHT, fontCache, fontSpecific, fontType, forceWidthsOutput, HELVETICA, HELVETICA_BOLD, HELVETICA_BOLDOBLIQUE, HELVETICA_OBLIQUE, IDENTITY_H, IDENTITY_V, ITALICANGLE, MACROMAN, NOT_CACHED, NOT_EMBEDDED, notdef, PARAGRAPH_SEPARATOR, RESOURCE_PATH, specialMap, STRIKETHROUGH_POSITION, STRIKETHROUGH_THICKNESS, SUBSCRIPT_OFFSET, SUBSCRIPT_SIZE, subset, subsetRanges, SUPERSCRIPT_OFFSET, SUPERSCRIPT_SIZE, SYMBOL, TIMES_BOLD, TIMES_BOLDITALIC, TIMES_ITALIC, TIMES_ROMAN, UNDERLINE_POSITION, UNDERLINE_THICKNESS, unicodeDifferences, vertical, WEIGHT_CLASS, WIDTH_CLASS, widths, WINANSI, ZAPFDINGBATS -
Constructor Summary
ConstructorsConstructorDescriptionTrueTypeFontUnicode(String ttFile, String enc, boolean emb, byte[] ttfAfm, boolean forceRead) Creates a new TrueType font addressed by Unicode characters. -
Method Summary
Modifier and TypeMethodDescriptionbooleancharExists(int c) Checks if a character exists in this font.intcompare(int[] o1, int[] o2) The method used to sort the metrics array.(package private) byte[]convertToBytes(int char1) Converts acharto a byte array according to the font's encoding.byte[]convertToBytes(String text) A forbidden operation.int[]getCharBBox(int c) Gets the smallest box enclosing the character contours.intGetCharFromGlyphId(int gid) getCIDFontType2(PdfIndirectReference fontDescriptor, String subsetPrefix, Object[] metrics) Generates the CIDFontTyte2 dictionary.getFontBaseType(PdfIndirectReference descendant, String subsetPrefix, PdfIndirectReference toUnicode) Generates the font dictionary.Returns a PdfStream object with the full font program.int[]getMetricsTT(int c) Gets the glyph index and metrics for a character.(package private) LanguagegetToUnicode(Object[] metrics) Creates a ToUnicode CMap to allow copy and paste from Acrobat.intgetWidth(int char1) Gets the width of acharin normalized 1000 units.intGets the width of aStringin normalized 1000 units.(package private) voidprocess(byte[] ttfAfm, boolean preload) Reads the font data.private voidbooleansetCharAdvance(int c, int advance) Sets the character advance.(package private) static StringtoHex(int n) Gets an hex string in the format "<HHHH>".private static StringtoHex4(int n) (package private) voidwriteFont(PdfWriter writer, PdfIndirectReference ref, Object[] params) Outputs to the writer the font dictionaries and streams.Methods inherited from class com.itextpdf.text.pdf.TrueTypeFont
addRangeUni, addRangeUni, checkCff, compactRanges, fillTables, getAllNameEntries, getAllNames, getBaseFont, getCodePagesSupported, getFamilyFontName, getFontBaseType, getFontDescriptor, getFontDescriptor, getFullFont, getFullFontName, getGlyphWidth, getKerning, getNames, getPostscriptFontName, getRawCharBBox, getRawWidth, getSubfamily, getSubSet, getTTCName, hasKernPairs, isWinAnsiSupported, readCffFont, readCMaps, readFormat0, readFormat12, readFormat4, readFormat6, readGlyphWidths, readKerning, readStandardString, readUnicodeString, setKerning, setPostscriptFontNameMethods inherited from class com.itextpdf.text.pdf.BaseFont
addSubsetRange, correctArabicAdvance, createBuiltInFontDictionary, createEncoding, createFont, createFont, createFont, createFont, createFont, createFont, createFont, createSubsetPrefix, enumerateTTCNames, enumerateTTCNames, getAllFontNames, getAllNameEntries, getAscent, getAscentPoint, getBaseName, getCidCode, getCompressionLevel, getDescent, getDescentPoint, getDifferences, getDocumentFonts, getDocumentFonts, getEncoding, getFontMatrix, getFontType, getFullFontName, getUnicodeDifferences, getUnicodeDifferences, getUnicodeEquivalent, getWidthPoint, getWidthPoint, getWidthPointKerned, getWidths, isDirectTextToByte, isEmbedded, isFontSpecific, isForceWidthsOutput, isSubset, isVertical, normalizeEncoding, setCompressionLevel, setDirectTextToByte, setFontDescriptor, setForceWidthsOutput, setSubsetMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface java.util.Comparator
equals, reversed, thenComparing, thenComparing, thenComparing, thenComparingDouble, thenComparingInt, thenComparingLong
-
Field Details
-
SUPPORTED_LANGUAGES_FOR_OTF
-
glyphSubstitutionMap
-
supportedLanguage
-
rotbits
private static final byte[] rotbits
-
-
Constructor Details
-
TrueTypeFontUnicode
TrueTypeFontUnicode(String ttFile, String enc, boolean emb, byte[] ttfAfm, boolean forceRead) throws DocumentException, IOException Creates a new TrueType font addressed by Unicode characters. The font will always be embedded.- Parameters:
ttFile- the location of the font on file. The file must end in '.ttf'. The modifiers after the name are ignored.enc- the encoding to be applied to this fontemb- true if the font is to be embedded in the PDFttfAfm- the font as abytearray- Throws:
DocumentException- the font is invalidIOException- the font file could not be read
-
-
Method Details
-
process
Description copied from class:TrueTypeFontReads the font data.- Overrides:
processin classTrueTypeFont- Parameters:
ttfAfm- the font as abytearray, possiblynull- Throws:
DocumentException- the font is invalidIOException- the font file could not be read
-
getWidth
public int getWidth(int char1) Gets the width of acharin normalized 1000 units. -
getWidth
Gets the width of aStringin normalized 1000 units. -
getToUnicode
Creates a ToUnicode CMap to allow copy and paste from Acrobat.- Parameters:
metrics- metrics[0] contains the glyph index and metrics[2] contains the Unicode code- Returns:
- the stream representing this CMap or
null
-
toHex4
-
toHex
Gets an hex string in the format "<HHHH>".- Parameters:
n- the number- Returns:
- the hex string
-
getCIDFontType2
public PdfDictionary getCIDFontType2(PdfIndirectReference fontDescriptor, String subsetPrefix, Object[] metrics) Generates the CIDFontTyte2 dictionary.- Parameters:
fontDescriptor- the indirect reference to the font descriptorsubsetPrefix- the subset prefixmetrics- the horizontal width metrics- Returns:
- a stream
-
getFontBaseType
public PdfDictionary getFontBaseType(PdfIndirectReference descendant, String subsetPrefix, PdfIndirectReference toUnicode) Generates the font dictionary.- Parameters:
descendant- the descendant dictionarysubsetPrefix- the subset prefixtoUnicode- the ToUnicode stream- Returns:
- the stream
-
GetCharFromGlyphId
public int GetCharFromGlyphId(int gid) -
compare
public int compare(int[] o1, int[] o2) The method used to sort the metrics array.- Specified by:
comparein interfaceComparator<int[]>- Parameters:
o1- the first elemento2- the second element- Returns:
- the comparison
-
writeFont
void writeFont(PdfWriter writer, PdfIndirectReference ref, Object[] params) throws DocumentException, IOException Outputs to the writer the font dictionaries and streams.- Overrides:
writeFontin classTrueTypeFont- 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
-
getFullFontStream
Returns a PdfStream object with the full font program.- Overrides:
getFullFontStreamin classTrueTypeFont- Returns:
- a PdfStream with the font program
- Throws:
IOExceptionDocumentException- Since:
- 2.1.3
-
convertToBytes
A forbidden operation. Will throw a null pointer exception.- Overrides:
convertToBytesin classBaseFont- Parameters:
text- the text- Returns:
- always
null
-
convertToBytes
byte[] convertToBytes(int char1) Description copied from class:BaseFontConverts acharto a byte array according to the font's encoding.- Overrides:
convertToBytesin classBaseFont- Parameters:
char1- thecharto be converted- Returns:
- an array of
byterepresenting the conversion according to the font's encoding
-
getMetricsTT
public int[] getMetricsTT(int c) Gets the glyph index and metrics for a character.- Overrides:
getMetricsTTin classTrueTypeFont- Parameters:
c- the character- Returns:
- an
intarray with {glyph index, width}
-
charExists
public boolean charExists(int c) Checks if a character exists in this font.- Overrides:
charExistsin classBaseFont- Parameters:
c- the character to check- Returns:
trueif the character has a glyph,falseotherwise
-
setCharAdvance
public boolean setCharAdvance(int c, int advance) Sets the character advance.- Overrides:
setCharAdvancein classBaseFont- Parameters:
c- the characteradvance- the character advance normalized to 1000 units- Returns:
trueif the advance was set,falseotherwise
-
getCharBBox
public int[] getCharBBox(int 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
-
getGlyphSubstitutionMap
-
getSupportedLanguage
Language getSupportedLanguage() -
readGsubTable
- Throws:
IOException
-