lookupKey.setFontFamily(fontFamily);
lookupKey.setFontSize(fontSize);
lookupKey.setBold(bold);
lookupKey.setItalics(italics);
final FontMetrics cached = (FontMetrics) fontMetricsCache.get(lookupKey);
if (cached != null)
{
return cached;
}
final FontRegistry registry = getFontRegistry();
FontFamily family = registry.getFontFamily(fontFamily);
if (family == null)
{
AbstractOutputProcessorMetaData.logger.warn("Unable to lookup the font family: " + fontFamily);
// Get the default font name
final String fallBack = getNormalizedFontFamilyName(null);
if (fallBack == null)
{
// If this case happens, the output-processor meta-data does not provide a sensible
// fall-back value. As we cannot continue without a font, we fail here instead of
// waiting for a NullPointer or other weird error later.
throw new IllegalArgumentException("No default family defined, aborting.");
}
family = registry.getFontFamily(fallBack);
if (family == null)
{
// If this case happens, the output-processor meta-data does not provide a sensible
// fall-back value. As we cannot continue without a font, we fail here instead of
// waiting for a NullPointer or other weird error later.
throw new IllegalArgumentException("Default family is invalid. Aborting.");
}
}
reusableFontContext.setAntiAliased(antiAliasing);
reusableFontContext.setFontSize(fontSize);
reusableFontContext.setEncoding(encoding);
reusableFontContext.setEmbedded(embedded);
final FontRecord record = family.getFontRecord(bold, italics);
final FontMetrics fm = getFontStorage().getFontMetrics(record.getIdentifier(), reusableFontContext);
if (fm == null)
{
// If this case happens, then the previous steps of mapping the font name into sensible
// defaults failed. The font-system's font-registry is not in sync with the actual font-metrics
// provider (which indicates that the LibFonts font-system implementation is invalid).