1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
|
/**
* ===========================================
* LibLayout : a free Java layouting library
* ===========================================
*
* Project Info: http://reporting.pentaho.org/liblayout/
*
* (C) Copyright 2006-2007, by Pentaho Corporation and Contributors.
*
* This library is free software; you can redistribute it and/or modify it under the terms
* of the GNU Lesser General Public License as published by the Free Software Foundation;
* either version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License along with this
* library; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
* Boston, MA 02111-1307, USA.
*
* [Java is a trademark or registered trademark of Sun Microsystems, Inc.
* in the United States and other countries.]
*
* ------------
* $Id: EndSequenceElement.java 2755 2007-04-10 19:27:09Z taqua $
* ------------
* (C) Copyright 2006-2007, by Pentaho Corporation.
*/
package org.jfree.layouting.renderer.process.layoutrules;
import org.jfree.layouting.renderer.model.InlineRenderBox;
import org.jfree.layouting.renderer.model.RenderNode;
import org.jfree.layouting.renderer.model.StaticBoxLayoutProperties;
import org.jfree.layouting.renderer.model.ComputedLayoutProperties;
/**
* This marks the end of an inline-element. It represents the border and
* padding. There is no break before such an element.
*
* @author Thomas Morgner
*/
public class EndSequenceElement implements InlineSequenceElement
{
private InlineRenderBox node;
public EndSequenceElement(final InlineRenderBox node)
{
this.node = node;
}
/**
* The width of the element. This is the minimum width of the element.
*
* @return
*/
public long getMinimumWidth()
{
final ComputedLayoutProperties blp = node.getComputedLayoutProperties();
return blp.getBorderRight() + blp.getPaddingRight() + blp.getMarginRight();
}
/**
* The extra-space width for an element. Some elements can expand to fill some
* more space (justified text is a good example, adding some space between the
* letters of each word to reduce the inner-word spacing).
*
* @return
*/
public long getMaximumWidth()
{
return getMinimumWidth();
}
public RenderNode getNode()
{
return node;
}
public boolean isPreserveWhitespace()
{
return node.isPreserveSpace();
}
}
|