diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/org/apache/fop/fo/flow/ExternalGraphic.java | 143 |
1 files changed, 90 insertions, 53 deletions
diff --git a/src/org/apache/fop/fo/flow/ExternalGraphic.java b/src/org/apache/fop/fo/flow/ExternalGraphic.java index 5fce31e8c..ebbefcb12 100644 --- a/src/org/apache/fop/fo/flow/ExternalGraphic.java +++ b/src/org/apache/fop/fo/flow/ExternalGraphic.java @@ -1,6 +1,6 @@ /* * $Id$ - * Copyright (C) 2001 The Apache Software Foundation. All rights reserved. + * Copyright (C) 2001-2002 The Apache Software Foundation. All rights reserved. * For details on use and redistribution please refer to the * LICENSE file included with these sources. */ @@ -8,45 +8,70 @@ package org.apache.fop.fo.flow; // FOP -import org.apache.fop.fo.*; -import org.apache.fop.fo.properties.*; -import org.apache.fop.layout.*; -import org.apache.fop.apps.FOPException; -import org.apache.fop.image.*; +import org.apache.fop.fo.FONode; +import org.apache.fop.fo.FObj; +import org.apache.fop.layout.AuralProps; +import org.apache.fop.layout.AccessibilityProps; +import org.apache.fop.layout.BorderAndPadding; +import org.apache.fop.layout.BackgroundProps; +import org.apache.fop.layout.MarginInlineProps; +import org.apache.fop.layout.RelativePositionProps; +import org.apache.fop.fo.properties.TextAlign; +import org.apache.fop.fo.properties.Overflow; +import org.apache.fop.fo.properties.DisplayAlign; +import org.apache.fop.fo.properties.Scaling; +import org.apache.fop.image.ImageFactory; +import org.apache.fop.image.FopImage; import org.apache.fop.area.inline.InlineArea; -import org.apache.fop.layoutmgr.LayoutManager; +import org.apache.fop.layoutmgr.AbstractLayoutManager; import org.apache.fop.layoutmgr.LeafNodeLayoutManager; import org.apache.fop.area.inline.Image; import org.apache.fop.area.inline.Viewport; -import org.apache.fop.datatypes.*; +import org.apache.fop.datatypes.Length; // Java -import java.net.URL; -import java.net.MalformedURLException; import java.util.List; import java.awt.geom.Rectangle2D; +/** + * External graphic formatting object. + * This FO node handles the external graphic. It creates an image + * inline area that can be added to the area tree. + */ public class ExternalGraphic extends FObj { - String url; - int breakAfter; - int breakBefore; - int align; - int startIndent; - int endIndent; - int spaceBefore; - int spaceAfter; - int viewWidth = -1; - int viewHeight = -1; - boolean clip = false; - Rectangle2D placement = null; + private String url; + private int breakAfter; + private int breakBefore; + private int align; + private int startIndent; + private int endIndent; + private int spaceBefore; + private int spaceAfter; + private int viewWidth = -1; + private int viewHeight = -1; + private boolean clip = false; + private Rectangle2D placement = null; + /** + * Create a new External graphic node. + * + * @param parent the parent of this node + */ public ExternalGraphic(FONode parent) { super(parent); } + /** + * Add the layout manager for this to the list. + * This adds a leafnode layout manager that deals with the + * created viewport/image area. + * + * @param list the list to add the layout manager to + */ public void addLayoutManager(List list) { InlineArea area = getInlineArea(); - if(area != null) { + if (area != null) { + setupID(); LeafNodeLayoutManager lm = new LeafNodeLayoutManager(this); lm.setCurrentArea(area); lm.setAlignment(properties.get("vertical-align").getEnum()); @@ -55,9 +80,15 @@ public class ExternalGraphic extends FObj { } } + /** + * Get the inline area for this external grpahic. + * This creates the image area and puts it inside a viewport. + * + * @return the viewport containing the image area + */ protected InlineArea getInlineArea() { setup(); - if(url == null) { + if (url == null) { return null; } Image imArea = new Image(url); @@ -68,32 +99,42 @@ public class ExternalGraphic extends FObj { vp.setContentPosition(placement); vp.setOffset(0); + // Common Border, Padding, and Background Properties + BorderAndPadding bap = propMgr.getBorderAndPadding(); + BackgroundProps bProps = propMgr.getBackgroundProps(); + AbstractLayoutManager.addBorders(vp, bap); + AbstractLayoutManager.addBackground(vp, bProps); + return vp; } + /** + * Setup this image. + * This gets the sizes for the image and the dimensions and clipping. + */ public void setup() { url = this.properties.get("src").getString(); - if(url == null) { + if (url == null) { return; } url = ImageFactory.getURL(url); // assume lr-tb for now Length ipd = properties.get("inline-progression-dimension.optimum").getLength(); - if(!ipd.isAuto()) { + if (!ipd.isAuto()) { viewWidth = ipd.mvalue(); } else { ipd = properties.get("width").getLength(); - if(!ipd.isAuto()) { + if (!ipd.isAuto()) { viewWidth = ipd.mvalue(); } } Length bpd = properties.get("block-progression-dimension.optimum").getLength(); - if(!bpd.isAuto()) { + if (!bpd.isAuto()) { viewHeight = bpd.mvalue(); } else { bpd = properties.get("height").getLength(); - if(!bpd.isAuto()) { + if (!bpd.isAuto()) { viewHeight = bpd.mvalue(); } } @@ -104,18 +145,18 @@ public class ExternalGraphic extends FObj { int cwidth = -1; int cheight = -1; Length ch = properties.get("content-height").getLength(); - if(!ch.isAuto()) { - /*if(ch.scaleToFit()) { - if(viewHeight != -1) { + if (!ch.isAuto()) { + /*if (ch.scaleToFit()) { + if (viewHeight != -1) { cheight = viewHeight; } } else {*/ cheight = ch.mvalue(); } Length cw = properties.get("content-width").getLength(); - if(!cw.isAuto()) { - /*if(cw.scaleToFit()) { - if(viewWidth != -1) { + if (!cw.isAuto()) { + /*if (cw.scaleToFit()) { + if (viewWidth != -1) { cwidth = viewWidth; } } else {*/ @@ -123,31 +164,31 @@ public class ExternalGraphic extends FObj { } int scaling = properties.get("scaling").getEnum(); - if((scaling == Scaling.UNIFORM) || (cwidth == -1) || cheight == -1) { + if ((scaling == Scaling.UNIFORM) || (cwidth == -1) || cheight == -1) { ImageFactory fact = ImageFactory.getInstance(); fopimage = fact.getImage(url, userAgent); - if(fopimage == null) { + if (fopimage == null) { // error url = null; return; } // load dimensions - if(!fopimage.load(FopImage.DIMENSIONS, userAgent)) { + if (!fopimage.load(FopImage.DIMENSIONS, userAgent)) { // error url = null; return; } - if(cwidth == -1) { + if (cwidth == -1) { cwidth = (int)(fopimage.getWidth() * 1000); } - if(cheight == -1) { + if (cheight == -1) { cheight = (int)(fopimage.getHeight() * 1000); } - if(scaling == Scaling.UNIFORM) { + if (scaling == Scaling.UNIFORM) { // adjust the larger double rat1 = cwidth / (fopimage.getWidth() * 1000f); double rat2 = cheight / (fopimage.getHeight() * 1000f); - if(rat1 < rat2) { + if (rat1 < rat2) { // reduce cheight cheight = (int)(rat1 * fopimage.getHeight() * 1000); } else { @@ -156,19 +197,20 @@ public class ExternalGraphic extends FObj { } } - if(viewWidth == -1) { + if (viewWidth == -1) { viewWidth = cwidth; } - if(viewHeight == -1) { + if (viewHeight == -1) { viewHeight = cheight; } - if(cwidth > viewWidth || cheight > viewHeight) { + if (cwidth > viewWidth || cheight > viewHeight) { int overflow = properties.get("overflow").getEnum(); - if(overflow == Overflow.HIDDEN) { + if (overflow == Overflow.HIDDEN) { clip = true; - } else if(overflow == Overflow.ERROR_IF_OVERFLOW) { - getLogger().error("Image: " + url + " overflows the viewport"); + } else if (overflow == Overflow.ERROR_IF_OVERFLOW) { + getLogger().error("Image: " + url + + " overflows the viewport, clipping to viewport"); clip = true; } } @@ -212,10 +254,6 @@ public class ExternalGraphic extends FObj { // Common Aural Properties AuralProps mAurProps = propMgr.getAuralProps(); - // Common Border, Padding, and Background Properties - BorderAndPadding bap = propMgr.getBorderAndPadding(); - BackgroundProps bProps = propMgr.getBackgroundProps(); - // Common Margin Properties-Inline MarginInlineProps mProps = propMgr.getMarginInlineProps(); @@ -227,7 +265,6 @@ public class ExternalGraphic extends FObj { // this.properties.get("baseline-shift"); // this.properties.get("content-type"); // this.properties.get("dominant-baseline"); - setupID(); // this.properties.get("keep-with-next"); // this.properties.get("keep-with-previous"); // this.properties.get("line-height"); |