Class FontInfo

java.lang.Object
org.apache.fop.fonts.FontInfo

public class FontInfo extends 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.
  • Field Details

    • log

      protected static final org.apache.commons.logging.Log log
      logging instance
    • usedFonts

      private Map<String,Typeface> usedFonts
      Map containing fonts that have been used
    • triplets

      private Map<FontTriplet,String> triplets
      look up a font-triplet to find a font-name
    • tripletPriorities

      private Map<FontTriplet,Integer> tripletPriorities
      look up a font-triplet to find its priority (only used inside addFontProperties())
    • fonts

      private Map<String,Typeface> fonts
      look up a font-name to get a font (that implements FontMetrics at least)
    • fontInstanceCache

      private Map<FontTriplet,Map<Integer,Font>> fontInstanceCache
      Cache for Font instances.
    • eventListener

      private FontEventListener eventListener
      Event listener for font events
  • Constructor Details

    • FontInfo

      public FontInfo()
      Main constructor
  • Method Details

    • setEventListener

      public void setEventListener(FontEventListener listener)
      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(String name, String family, String style, int weight)
      Adds a new font triplet.
      Parameters:
      name - internal key
      family - font family name
      style - font style (normal, italic, oblique...)
      weight - font weight
    • addFontProperties

      public void addFontProperties(String name, String[] families, String style, int weight)
      Adds a series of new font triplets given an array of font family names.
      Parameters:
      name - internal key
      families - an array of font family names
      style - font style (normal, italic, oblique...)
      weight - font weight
    • addFontProperties

      public void addFontProperties(String internalFontKey, FontTriplet triplet)
      Adds a new font triplet.
      Parameters:
      internalFontKey - internal font key
      triplet - the font triplet to associate with the internal key
    • logDuplicateFont

      private void logDuplicateFont(FontTriplet triplet, boolean replacing, String oldKey, int oldPriority, String newKey, int newPriority)
      Log warning about duplicate font triplets.
      Parameters:
      triplet - the duplicate font triplet
      replacing - true iff the new font will replace the old one
      oldKey - the old internal font name
      oldPriority - the priority of the existing font mapping
      newKey - the new internal font name
      newPriority - the priority of the duplicate font mapping
    • addMetrics

      public void addMetrics(String internalFontKey, FontMetrics metrics)
      Adds font metrics for a specific font.
      Parameters:
      internalFontKey - internal key
      metrics - metrics to register
    • fontLookup

      private FontTriplet fontLookup(String family, String style, int weight, boolean substitutable)
      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 family
      style - font style
      weight - font weight
      substitutable - true if the font may be substituted with the default font if not found
      Returns:
      internal font triplet key
    • fuzzyFontLookup

      private FontTriplet fuzzyFontLookup(String family, String style, int weight, FontTriplet startKey, boolean substitutable)
    • useFont

      public void useFont(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.)
    • getFontInstanceCache

      private Map<FontTriplet,Map<Integer,Font>> getFontInstanceCache()
    • getFontInstance

      public Font getFontInstance(FontTriplet triplet, int fontSize)
      Retrieves a (possibly cached) Font instance based on a FontTriplet and a font size.
      Parameters:
      triplet - the font triplet designating the requested font
      fontSize - the font size
      Returns:
      the requested Font instance
    • getTripletsForName

      private List<FontTriplet> getTripletsForName(String fontName)
    • getFontInstanceForAWTFont

      public Font getFontInstanceForAWTFont(Font awtFont)
      Returns a suitable internal font given an AWT Font instance.
      Parameters:
      awtFont - the AWT font
      Returns:
      a best matching internal Font
    • fontLookup

      public FontTriplet fontLookup(String family, String style, int weight)
      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 family
      style - font style
      weight - font weight
      Returns:
      the font triplet of the font chosen
    • fontLookup

      private List<FontTriplet> fontLookup(String[] families, String style, int weight, boolean substitutable)
    • fontLookup

      public FontTriplet[] fontLookup(String[] families, String style, int weight)
      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 style
      weight - font weight
      Returns:
      the set of font triplets of all supported and chosen font-families in the specified style and weight.
    • notifyFontReplacement

      private void notifyFontReplacement(FontTriplet replacedKey, FontTriplet newKey)
    • notifyStrokingSVGTextAsShapes

      public void notifyStrokingSVGTextAsShapes(String fontFamily)
      Notify listeners that the SVG text for the given font will be stroked as shapes.
      Parameters:
      fontFamily - a SVG font family
    • findAdjustWeight

      public FontTriplet findAdjustWeight(String family, String style, int weight)
      Find a font with a given family and style by trying different font weights according to the spec.
      Parameters:
      family - font family
      style - font style
      weight - font weight
      Returns:
      internal key
    • hasFont

      public boolean hasFont(String family, String style, int weight)
      Determines if a particular font is available.
      Parameters:
      family - font family
      style - font style
      weight - font weight
      Returns:
      True if available
    • getInternalFontKey

      public String getInternalFontKey(FontTriplet triplet)
      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(String family, String style, int weight)
      Creates a key from the given strings.
      Parameters:
      family - font family
      style - font style
      weight - font weight
      Returns:
      internal key
    • getFonts

      public Map<String,Typeface> getFonts()
      Gets a Map of all registered fonts.
      Returns:
      a read-only Map with font key/FontMetrics pairs
    • getFontTriplets

      public Map<FontTriplet,String> getFontTriplets()
      Gets a Map of all registered font triplets.
      Returns:
      a Map with FontTriplet/font key pairs
    • getUsedFonts

      public Map<String,Typeface> 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

      public FontMetrics getMetricsFor(String fontName)
      Returns the FontMetrics for a particular font
      Parameters:
      fontName - internal key
      Returns:
      font metrics
    • getTripletsFor

      public List<FontTriplet> getTripletsFor(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

      public FontTriplet getTripletFor(String fontName)
      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 String getFontStyleFor(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(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.