01: /*
02:
03: Licensed to the Apache Software Foundation (ASF) under one or more
04: contributor license agreements. See the NOTICE file distributed with
05: this work for additional information regarding copyright ownership.
06: The ASF licenses this file to You under the Apache License, Version 2.0
07: (the "License"); you may not use this file except in compliance with
08: the License. You may obtain a copy of the License at
09:
10: http://www.apache.org/licenses/LICENSE-2.0
11:
12: Unless required by applicable law or agreed to in writing, software
13: distributed under the License is distributed on an "AS IS" BASIS,
14: WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15: See the License for the specific language governing permissions and
16: limitations under the License.
17:
18: */
19: package org.apache.batik.gvt.text;
20:
21: import java.awt.font.FontRenderContext;
22: import java.awt.geom.Point2D;
23: import java.text.AttributedCharacterIterator;
24:
25: /**
26: * Factory instance that returns TextSpanLayouts appropriate to
27: * AttributedCharacterIterator instances.
28: *
29: * @see org.apache.batik.gvt.text.TextSpanLayout
30: * @author <a href="mailto:bill.haneman@ireland.sun.com">Bill Haneman</a>
31: * @version $Id: ConcreteTextLayoutFactory.java 475477 2006-11-15 22:44:28Z cam $
32: */
33: public class ConcreteTextLayoutFactory implements TextLayoutFactory {
34:
35: /**
36: * Returns an instance of TextSpanLayout suitable for rendering the
37: * AttributedCharacterIterator.
38: *
39: * @param aci The character iterator to be laid out
40: * @param charMap Indicates how chars in aci map to original
41: * text char array.
42: * @param offset The offset position for the text layout.
43: * @param frc The font render context to use when creating the text layout.
44: */
45: public TextSpanLayout createTextLayout(
46: AttributedCharacterIterator aci, int[] charMap,
47: Point2D offset, FontRenderContext frc) {
48: return new GlyphLayout(aci, charMap, offset, frc);
49: }
50: }
|