/*****************************************************************************
* Copyright (C) The Apache Software Foundation. All rights reserved. *
* ------------------------------------------------------------------------- *
* This software is published under the terms of the Apache Software License *
* version 1.1, a copy of which has been included with this distribution in *
* the LICENSE file. *
*****************************************************************************/
package org.apache.batik.bridge;
import org.apache.batik.gvt.font.AltGlyphHandler;
import org.apache.batik.gvt.font.GVTGlyphVector;
import org.apache.batik.gvt.font.SVGGVTGlyphVector;
import org.apache.batik.gvt.font.Glyph;
import org.apache.batik.util.SVGConstants;
import java.awt.font.FontRenderContext;
import org.w3c.dom.Element;
/**
* SVG font altGlyph handler. This class handles the creation of an alternate
* GVTGlyphVector for the altGlyph element.
*
* @author <a href="mailto:bella.robinson@cmis.csiro.au">Bella Robinson</a>
* @version $Id: SVGAltGlyphHandler.java,v 1.3 2001/07/05 06:56:07 bella Exp $
*/
public class SVGAltGlyphHandler implements AltGlyphHandler, SVGConstants {
private BridgeContext ctx;
private Element textElement;
/**
* Constructs an SVGAltGlyphHandler.
*
* @param ctx The bridge context, this is needed during rendering to find
* any referenced glyph elements.
* @param textElement The element that contains text to be replaced by the
* alternate glyphs. This should be an altGlyph element.
*/
public SVGAltGlyphHandler(BridgeContext ctx, Element textElement) {
this.ctx = ctx;
this.textElement = textElement;
}
/**
* Creates a glyph vector containing the alternate glyphs.
*
* @param frc The current font render context.
* @param fontSize The required font size.
* @return The GVTGlyphVector containing the alternate glyphs, or null if
* the alternate glyphs could not be found.
*/
public GVTGlyphVector createGlyphVector(FontRenderContext frc, float fontSize) {
if (textElement.getTagName().equals(SVG_ALT_GLYPH_TAG)) {
SVGAltGlyphElementBridge altGlyphBridge = (SVGAltGlyphElementBridge)ctx.getBridge(textElement);
Glyph[] glyphArray = altGlyphBridge.createAltGlyphArray(ctx, textElement, fontSize);
if (glyphArray != null) {
return new SVGGVTGlyphVector(null, glyphArray, frc);
}
}
return null;
}
}