/*
 * 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: AbstractGraphics.java 1733431 2016-03-03 09:40:50Z gadams $ */

package org.apache.fop.fo.flow;

import java.util.Stack;

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.FONode;
import org.apache.fop.fo.FObj;
import org.apache.fop.fo.GraphicsProperties;
import org.apache.fop.fo.PropertyList;
import org.apache.fop.fo.properties.CommonAccessibility;
import org.apache.fop.fo.properties.CommonAccessibilityHolder;
import org.apache.fop.fo.properties.CommonBorderPaddingBackground;
import org.apache.fop.fo.properties.KeepProperty;
import org.apache.fop.fo.properties.LengthRangeProperty;
import org.apache.fop.fo.properties.SpaceProperty;
import org.apache.fop.fo.properties.StructureTreeElementHolder;
import org.apache.fop.util.CharUtilities;

Common base class for the fo:instream-foreign-object and fo:external-graphic flow formatting objects.
/** * Common base class for the <a href="http://www.w3.org/TR/xsl/#fo_instream-foreign-object"> * <code>fo:instream-foreign-object</code></a> * and <a href="http://www.w3.org/TR/xsl/#fo_external-graphic"> * <code>fo:external-graphic</code></a> flow formatting objects. */
public abstract class AbstractGraphics extends FObj implements GraphicsProperties, StructureTreeElementHolder, CommonAccessibilityHolder { // The value of properties relevant for fo:instream-foreign-object // and external-graphics. private CommonAccessibility commonAccessibility; private CommonBorderPaddingBackground commonBorderPaddingBackground; private Length alignmentAdjust; private int alignmentBaseline; private Length baselineShift; private LengthRangeProperty blockProgressionDimension; // private ToBeImplementedProperty clip; private Length contentHeight; private Length contentWidth; private int displayAlign; private int dominantBaseline; private Length height; private LengthRangeProperty inlineProgressionDimension; private KeepProperty keepWithNext; private KeepProperty keepWithPrevious; private SpaceProperty lineHeight; private int overflow; private int scaling; private int textAlign; private Length width; private String altText; private StructureTreeElement structureTreeElement; // Unused but valid items, commented out for performance: // private CommonAccessibility commonAccessibility; // private CommonAural commonAural; // private CommonMarginInline commonMarginInline; // private CommonRelativePosition commonRelativePosition; // private String contentType; // private int scalingMethod; // End of property values
constructs an instream-foreign-object object (called by Maker).
Params:
  • parent – the parent formatting object
/** * constructs an instream-foreign-object object (called by Maker). * * @param parent the parent formatting object */
public AbstractGraphics(FONode parent) { super(parent); }
{@inheritDoc}
/** {@inheritDoc} */
public void bind(PropertyList pList) throws FOPException { super.bind(pList); commonAccessibility = CommonAccessibility.getInstance(pList); commonBorderPaddingBackground = pList.getBorderPaddingBackgroundProps(); alignmentAdjust = pList.get(PR_ALIGNMENT_ADJUST).getLength(); alignmentBaseline = pList.get(PR_ALIGNMENT_BASELINE).getEnum(); baselineShift = pList.get(PR_BASELINE_SHIFT).getLength(); blockProgressionDimension = pList.get(PR_BLOCK_PROGRESSION_DIMENSION).getLengthRange(); // clip = pList.get(PR_CLIP); contentHeight = pList.get(PR_CONTENT_HEIGHT).getLength(); contentWidth = pList.get(PR_CONTENT_WIDTH).getLength(); displayAlign = pList.get(PR_DISPLAY_ALIGN).getEnum(); dominantBaseline = pList.get(PR_DOMINANT_BASELINE).getEnum(); height = pList.get(PR_HEIGHT).getLength(); inlineProgressionDimension = pList.get(PR_INLINE_PROGRESSION_DIMENSION).getLengthRange(); keepWithNext = pList.get(PR_KEEP_WITH_NEXT).getKeep(); keepWithPrevious = pList.get(PR_KEEP_WITH_PREVIOUS).getKeep(); lineHeight = pList.get(PR_LINE_HEIGHT).getSpace(); overflow = pList.get(PR_OVERFLOW).getEnum(); scaling = pList.get(PR_SCALING).getEnum(); textAlign = pList.get(PR_TEXT_ALIGN).getEnum(); width = pList.get(PR_WIDTH).getLength(); if (getUserAgent().isAccessibilityEnabled()) { altText = pList.get(PR_X_ALT_TEXT).getString(); if (altText.equals("")) { getFOValidationEventProducer().altTextMissing(this, getLocalName(), getLocator()); } } }
{@inheritDoc}
/** {@inheritDoc} */
public CommonAccessibility getCommonAccessibility() { return commonAccessibility; }
Returns:the CommonBorderPaddingBackground
/** @return the {@link CommonBorderPaddingBackground} */
public CommonBorderPaddingBackground getCommonBorderPaddingBackground() { return commonBorderPaddingBackground; }
Returns:the "line-height" property
/** @return the "line-height" property */
public SpaceProperty getLineHeight() { return lineHeight; }
Returns:the "inline-progression-dimension" property
/** @return the "inline-progression-dimension" property */
public LengthRangeProperty getInlineProgressionDimension() { return inlineProgressionDimension; }
Returns:the "block-progression-dimension" property
/** @return the "block-progression-dimension" property */
public LengthRangeProperty getBlockProgressionDimension() { return blockProgressionDimension; }
Returns:the "height" property
/** @return the "height" property */
public Length getHeight() { return height; }
Returns:the "width" property
/** @return the "width" property */
public Length getWidth() { return width; }
Returns:the "content-height" property
/** @return the "content-height" property */
public Length getContentHeight() { return contentHeight; }
Returns:the "content-width" property
/** @return the "content-width" property */
public Length getContentWidth() { return contentWidth; }
Returns:the "scaling" property
/** @return the "scaling" property */
public int getScaling() { return scaling; }
Returns:the "overflow" property
/** @return the "overflow" property */
public int getOverflow() { return overflow; }
{@inheritDoc}
/** {@inheritDoc} */
public int getDisplayAlign() { return displayAlign; }
{@inheritDoc}
/** {@inheritDoc} */
public int getTextAlign() { return textAlign; }
Returns:the "alignment-adjust" property
/** @return the "alignment-adjust" property */
public Length getAlignmentAdjust() { if (alignmentAdjust.getEnum() == EN_AUTO) { final Length intrinsicAlignmentAdjust = this.getIntrinsicAlignmentAdjust(); if (intrinsicAlignmentAdjust != null) { return intrinsicAlignmentAdjust; } } 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 "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; }
Returns: the alternative text property.
/** @return the alternative text property. */
public String getAltText() { return altText; }
Returns:the graphic's intrinsic width in millipoints
/** @return the graphic's intrinsic width in millipoints */
public abstract int getIntrinsicWidth();
Returns:the graphic's intrinsic height in millipoints
/** @return the graphic's intrinsic height in millipoints */
public abstract int getIntrinsicHeight();
Returns:the graphic's intrinsic alignment-adjust
/** @return the graphic's intrinsic alignment-adjust */
public abstract Length getIntrinsicAlignmentAdjust(); @Override public boolean isDelimitedTextRangeBoundary(int boundary) { return false; } @Override protected Stack<DelimitedTextRange> collectDelimitedTextRanges(Stack<DelimitedTextRange> ranges, DelimitedTextRange currentRange) { if (currentRange != null) { currentRange.append(CharUtilities.OBJECT_REPLACEMENT_CHARACTER, this); } return ranges; } }