Package org.docx4j.fonts.fop.fonts
Class FontInfo
java.lang.Object
org.docx4j.fonts.fop.fonts.FontInfo
public class FontInfo
extends java.lang.Object
The FontInfo holds font information for the layout and rendering of a fo document.
This stores the list of available fonts that are setup by
the renderer. The font name can be retrieved for the
family style and weight.
Currently font supported font-variant small-caps is not implemented.
Currently font supported font-variant small-caps is not implemented.
-
Field Summary
Fields Modifier and Type Field Description protected static org.slf4j.Loggerloglogging instance -
Constructor Summary
Constructors Constructor Description FontInfo()Main constructor -
Method Summary
Modifier and Type Method Description voidaddFontProperties(java.lang.String name, java.lang.String[] families, java.lang.String style, int weight)Adds a series of new font triplets given an array of font family names.voidaddFontProperties(java.lang.String name, java.lang.String family, java.lang.String style, int weight)Adds a new font triplet.voidaddFontProperties(java.lang.String internalFontKey, FontTriplet triplet)Adds a new font triplet.voidaddMetrics(java.lang.String internalFontKey, FontMetrics metrics)Adds font metrics for a specific font.static FontTripletcreateFontKey(java.lang.String family, java.lang.String style, int weight)Creates a key from the given strings.voiddumpAllTripletsToSystemOut()Diagnostic method for logging all registered fonts to System.out.FontTripletfindAdjustWeight(java.lang.String family, java.lang.String style, int weight)Find a font with a given family and style by trying different font weights according to the spec.FontTriplet[]fontLookup(java.lang.String[] families, java.lang.String style, int weight)Looks up a set of fonts.FontTripletfontLookup(java.lang.String family, java.lang.String style, int weight)Lookup a font.FontgetFontInstance(FontTriplet triplet, int fontSize)Retrieves a (possibly cached) Font instance based on a FontTriplet and a font size.FontgetFontInstanceForAWTFont(java.awt.Font awtFont)Returns a suitable internal font given an AWT Font instance.java.util.MapgetFonts()Gets a Map of all registered fonts.java.lang.StringgetFontStyleFor(java.lang.String fontName)Returns the font style for a particular font.java.util.MapgetFontTriplets()Gets a Map of all registered font triplets.intgetFontWeightFor(java.lang.String fontName)Returns the font weight for a particular font.java.lang.StringgetInternalFontKey(FontTriplet triplet)Returns the internal font key (F1, F2, F3 etc.) for a given triplet.FontMetricsgetMetricsFor(java.lang.String fontName)Returns the FontMetrics for a particular fontFontTripletgetTripletFor(java.lang.String fontName)Returns the first triplet matching the given font name.java.util.ListgetTripletsFor(java.lang.String fontName)Returns all font triplet matching the given font name.java.util.MapgetUsedFonts()This is used by the renderers to retrieve all the fonts used in the document.booleanhasFont(java.lang.String family, java.lang.String style, int weight)Determines if a particular font is available.booleanisSetupValid()Checks if the font setup is valid (At least the ultimate fallback font must be registered.)voidsetEventListener(FontEventListener listener)Sets the font event listener that can be used to receive events about particular events in this class.java.lang.StringtoString()voiduseFont(java.lang.String internalName)Tells this class that the font with the given internal name has been used.
-
Field Details
-
log
protected static org.slf4j.Logger loglogging instance
-
-
Constructor Details
-
FontInfo
public FontInfo()Main constructor
-
-
Method Details
-
setEventListener
Sets the font event listener that can be used to receive events about particular events in this class.- Parameters:
listener- the font event listener
-
isSetupValid
public boolean isSetupValid()Checks if the font setup is valid (At least the ultimate fallback font must be registered.)- Returns:
- True if valid
-
addFontProperties
public void addFontProperties(java.lang.String name, java.lang.String family, java.lang.String style, int weight)Adds a new font triplet.- Parameters:
name- internal keyfamily- font family namestyle- font style (normal, italic, oblique...)weight- font weight
-
addFontProperties
public void addFontProperties(java.lang.String name, java.lang.String[] families, java.lang.String style, int weight)Adds a series of new font triplets given an array of font family names.- Parameters:
name- internal keyfamilies- an array of font family namesstyle- font style (normal, italic, oblique...)weight- font weight
-
addFontProperties
Adds a new font triplet.- Parameters:
internalFontKey- internal font keytriplet- the font triplet to associate with the internal key
-
addMetrics
Adds font metrics for a specific font.- Parameters:
internalFontKey- internal keymetrics- metrics to register
-
useFont
public void useFont(java.lang.String internalName)Tells this class that the font with the given internal name has been used.- Parameters:
internalName- the internal font name (F1, F2 etc.)
-
getFontInstance
Retrieves a (possibly cached) Font instance based on a FontTriplet and a font size.- Parameters:
triplet- the font triplet designating the requested fontfontSize- the font size- Returns:
- the requested Font instance
-
getFontInstanceForAWTFont
Returns a suitable internal font given an AWT Font instance.- Parameters:
awtFont- the AWT font- Returns:
- a best matching internal Font
-
fontLookup
Lookup a font.
Locate the font name for a given family, style and weight. The font name can then be used as a key as it is unique for the associated document. This also adds the font to the list of used fonts.- Parameters:
family- font familystyle- font styleweight- font weight- Returns:
- the font triplet of the font chosen
-
fontLookup
Looks up a set of fonts.
Locate the font name(s) for the given families, style and weight. The font name(s) can then be used as a key as they are unique for the associated document. This also adds the fonts to the list of used fonts.- Parameters:
families- font families (priority list)style- font styleweight- font weight- Returns:
- the set of font triplets of all supported and chosen font-families in the specified style and weight.
-
findAdjustWeight
Find a font with a given family and style by trying different font weights according to the spec.- Parameters:
family- font familystyle- font styleweight- font weight- Returns:
- internal key
-
hasFont
public boolean hasFont(java.lang.String family, java.lang.String style, int weight)Determines if a particular font is available.- Parameters:
family- font familystyle- font styleweight- font weight- Returns:
- True if available
-
getInternalFontKey
Returns the internal font key (F1, F2, F3 etc.) for a given triplet.- Parameters:
triplet- the font triplet- Returns:
- the associated internal key or null, if not found
-
createFontKey
public static FontTriplet createFontKey(java.lang.String family, java.lang.String style, int weight)Creates a key from the given strings.- Parameters:
family- font familystyle- font styleweight- font weight- Returns:
- internal key
-
getFonts
public java.util.Map getFonts()Gets a Map of all registered fonts.- Returns:
- a read-only Map with font key/FontMetrics pairs
-
getFontTriplets
public java.util.Map getFontTriplets()Gets a Map of all registered font triplets.- Returns:
- a Map with FontTriplet/font key pairs
-
getUsedFonts
public java.util.Map getUsedFonts()This is used by the renderers to retrieve all the fonts used in the document. This is for embedded font or creating a list of used fonts.- Returns:
- a read-only Map with font key/FontMetrics pairs
-
getMetricsFor
Returns the FontMetrics for a particular font- Parameters:
fontName- internal key- Returns:
- font metrics
-
getTripletsFor
public java.util.List getTripletsFor(java.lang.String fontName)Returns all font triplet matching the given font name.- Parameters:
fontName- The font name we are looking for- Returns:
- A list of matching font triplets
-
getTripletFor
Returns the first triplet matching the given font name. As there may be multiple triplets matching the font name the result set is sorted first to guarantee consistent results.- Parameters:
fontName- The font name we are looking for- Returns:
- The first triplet for the given font name
-
getFontStyleFor
public java.lang.String getFontStyleFor(java.lang.String fontName)Returns the font style for a particular font. There may be multiple font styles matching this font. Only the first found is returned. Searching is done on a sorted list to guarantee consistent results.- Parameters:
fontName- internal key- Returns:
- font style
-
getFontWeightFor
public int getFontWeightFor(java.lang.String fontName)Returns the font weight for a particular font. There may be multiple font weights matching this font. Only the first found is returned. Searching is done on a sorted list to guarantee consistent results.- Parameters:
fontName- internal key- Returns:
- font weight
-
dumpAllTripletsToSystemOut
public void dumpAllTripletsToSystemOut()Diagnostic method for logging all registered fonts to System.out. -
toString
public java.lang.String toString()- Overrides:
toStringin classjava.lang.Object
-