/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/* $Id: PSTextElementBridge.java 1805173 2017-08-16 10:50:04Z ssteiner $ */

package org.apache.fop.render.ps;

import org.w3c.dom.Element;

import org.apache.batik.bridge.BridgeContext;
import org.apache.batik.bridge.SVGTextElementBridge;
import org.apache.batik.bridge.TextNode;
import org.apache.batik.bridge.TextPainter;
import org.apache.batik.gvt.GraphicsNode;

Bridge class for the <text> element. This bridge will use the direct text painter if the text for the element is simple.
/** * Bridge class for the &lt;text&gt; element. * This bridge will use the direct text painter if the text * for the element is simple. */
public class PSTextElementBridge extends SVGTextElementBridge { private TextPainter textPainter;
Constructs a new bridge for the <text> element.
Params:
  • textPainter – the text painter to use
/** * Constructs a new bridge for the &lt;text&gt; element. * @param textPainter the text painter to use */
public PSTextElementBridge(TextPainter textPainter) { this.textPainter = textPainter; }
Create a text element bridge. This set the text painter on the node if the text is simple.
Params:
  • ctx – the bridge context
  • e – the svg element
Returns:the text graphics node created by the super class
/** * Create a text element bridge. * This set the text painter on the node if the text is simple. * @param ctx the bridge context * @param e the svg element * @return the text graphics node created by the super class */
public GraphicsNode createGraphicsNode(BridgeContext ctx, Element e) { GraphicsNode node = super.createGraphicsNode(ctx, e); ((TextNode)node).setTextPainter(getTextPainter()); return node; } private TextPainter getTextPainter() { return this.textPainter; } }