/*
 * 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: Character.java 1608314 2014-07-06 23:46:18Z gadams $ */

package org.apache.fop.fo.flow;

import java.awt.Color;
import java.util.NoSuchElementException;
import java.util.Stack;

import org.xml.sax.Locator;

import org.apache.fop.accessibility.StructureTreeElement;
import org.apache.fop.apps.FOPException;
import org.apache.fop.complexscripts.bidi.DelimitedTextRange;
import org.apache.fop.datatypes.Length;
import org.apache.fop.fo.CharIterator;
import org.apache.fop.fo.FONode;
import org.apache.fop.fo.FObj;
import org.apache.fop.fo.PropertyList;
import org.apache.fop.fo.ValidationException;
import org.apache.fop.fo.properties.CommonBorderPaddingBackground;
import org.apache.fop.fo.properties.CommonFont;
import org.apache.fop.fo.properties.CommonHyphenation;
import org.apache.fop.fo.properties.CommonTextDecoration;
import org.apache.fop.fo.properties.KeepProperty;
import org.apache.fop.fo.properties.Property;
import org.apache.fop.fo.properties.SpaceProperty;
import org.apache.fop.fo.properties.StructureTreeElementHolder;

Class modelling the fo:character object.
/** * Class modelling the <a href="http://www.w3.org/TR/xsl/#fo_character"> * <code>fo:character</code></a> object. */
public class Character extends FObj implements StructureTreeElementHolder { // The value of properties relevant for fo:character. private CommonBorderPaddingBackground commonBorderPaddingBackground; private CommonFont commonFont; private CommonHyphenation commonHyphenation; private Length alignmentAdjust; private int alignmentBaseline; private Length baselineShift; private char character; private Color color; private int dominantBaseline; private KeepProperty keepWithNext; private KeepProperty keepWithPrevious; private Property letterSpacing; private SpaceProperty lineHeight;
Holds the text decoration values. May be null
/** Holds the text decoration values. May be null */
private CommonTextDecoration textDecoration; // private ToBeImplementedProperty textShadow; private Property wordSpacing; private StructureTreeElement structureTreeElement; // Unused but valid items, commented out for performance: // private CommonAural commonAural; // private CommonMarginInline commonMarginInline; // private CommonRelativePosition commonRelativePosition; // private ToBeImplementedProperty glyphOrientationHorizontal; // private ToBeImplementedProperty glyphOrientationVertical; // private int treatAsWordSpace; // private Length textDepth; // private Length textAltitude; // private int scoreSpaces; // private int suppressAtLineBreak; // private int textTransform; // private int visibility; // End of property values
constant indicating that the character is OK
/** constant indicating that the character is OK */
public static final int OK = 0;
constant indicating that the character does not fit
/** constant indicating that the character does not fit */
public static final int DOESNOT_FIT = 1;
Params:
  • parent – FONode that is the parent of this object
/** * @param parent {@link FONode} that is the parent of this object */
public Character(FONode parent) { super(parent); }
{@inheritDoc}
/** {@inheritDoc} */
public void bind(PropertyList pList) throws FOPException { super.bind(pList); commonBorderPaddingBackground = pList.getBorderPaddingBackgroundProps(); commonFont = pList.getFontProps(); commonHyphenation = pList.getHyphenationProps(); alignmentAdjust = pList.get(PR_ALIGNMENT_ADJUST).getLength(); alignmentBaseline = pList.get(PR_ALIGNMENT_BASELINE).getEnum(); baselineShift = pList.get(PR_BASELINE_SHIFT).getLength(); character = pList.get(PR_CHARACTER).getCharacter(); color = pList.get(PR_COLOR).getColor(getUserAgent()); dominantBaseline = pList.get(PR_DOMINANT_BASELINE).getEnum(); keepWithNext = pList.get(PR_KEEP_WITH_NEXT).getKeep(); keepWithPrevious = pList.get(PR_KEEP_WITH_PREVIOUS).getKeep(); letterSpacing = pList.get(PR_LETTER_SPACING); lineHeight = pList.get(PR_LINE_HEIGHT).getSpace(); textDecoration = pList.getTextDecorationProps(); wordSpacing = pList.get(PR_WORD_SPACING); }
{@inheritDoc}
/** {@inheritDoc} */
public void startOfNode() throws FOPException { super.startOfNode(); getFOEventHandler().character(this); }
{@inheritDoc}
XSL Content Model: empty
/** * {@inheritDoc} * <br>XSL Content Model: empty */
protected void validateChildNode(Locator loc, String nsURI, String localName) throws ValidationException { if (FO_URI.equals(nsURI)) { invalidChildError(loc, nsURI, localName); } }
{@inheritDoc}
/** {@inheritDoc} */
public CharIterator charIterator() { return new FOCharIterator(this); }
Returns:the Common Border, Padding, and Background Properties
/** @return the Common Border, Padding, and Background Properties */
public CommonBorderPaddingBackground getCommonBorderPaddingBackground() { return commonBorderPaddingBackground; }
Returns:the Common Font Properties
/** @return the Common Font Properties */
public CommonFont getCommonFont() { return commonFont; }
Returns:the Common Hyphenation Properties
/** @return the Common Hyphenation Properties */
public CommonHyphenation getCommonHyphenation() { return commonHyphenation; }
Returns:the "character" property
/** @return the "character" property */
public char getCharacter() { return character; }
Returns:the "color" property
/** @return the "color" property */
public Color getColor() { return color; }
Returns:the "alignment-adjust" property
/** @return the "alignment-adjust" property */
public Length getAlignmentAdjust() { return alignmentAdjust; }
Returns:the "alignment-baseline" property
/** @return the "alignment-baseline" property */
public int getAlignmentBaseline() { return alignmentBaseline; }
Returns:the "baseline-shift" property
/** @return the "baseline-shift" property */
public Length getBaselineShift() { return baselineShift; }
Returns:the "dominant-baseline" property
/** @return the "dominant-baseline" property */
public int getDominantBaseline() { return dominantBaseline; }
Returns:the "letter-spacing" property
/** @return the "letter-spacing" property */
public Property getLetterSpacing() { return letterSpacing; }
Returns:the "line-height" property
/** @return the "line-height" property */
public SpaceProperty getLineHeight() { return lineHeight; }
Returns:the "text-decoration" property.
/** @return the "text-decoration" property. */
public CommonTextDecoration getTextDecoration() { return textDecoration; }
Returns:the "word-spacing" property
/** @return the "word-spacing" property */
public Property getWordSpacing() { return wordSpacing; }
Returns:the "keep-with-next" property
/** @return the "keep-with-next" property */
public KeepProperty getKeepWithNext() { return keepWithNext; }
Returns:the "keep-with-previous" property
/** @return the "keep-with-previous" property */
public KeepProperty getKeepWithPrevious() { return keepWithPrevious; } @Override public void setStructureTreeElement(StructureTreeElement structureTreeElement) { this.structureTreeElement = structureTreeElement; } @Override public StructureTreeElement getStructureTreeElement() { return structureTreeElement; }
{@inheritDoc}
/** {@inheritDoc} */
public String getLocalName() { return "character"; }
{@inheritDoc}
Returns:Constants.FO_CHARACTER
/** * {@inheritDoc} * @return {@link org.apache.fop.fo.Constants#FO_CHARACTER} */
public int getNameId() { return FO_CHARACTER; } @Override public boolean isDelimitedTextRangeBoundary(int boundary) { return false; } @Override protected Stack<DelimitedTextRange> collectDelimitedTextRanges(Stack<DelimitedTextRange> ranges, DelimitedTextRange currentRange) { if (currentRange != null) { currentRange.append(charIterator(), this); } return ranges; } private class FOCharIterator extends CharIterator { private boolean bFirst = true; private Character foChar; FOCharIterator(Character foChar) { this.foChar = foChar; } public boolean hasNext() { return bFirst; } public char nextChar() { if (bFirst) { bFirst = false; return foChar.character; } else { throw new NoSuchElementException(); } } public void remove() { foChar.parent.removeChild(foChar); } public void replaceChar(char c) { foChar.character = c; } } }