/*
* Copyright 2014-15 Skynav, Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY SKYNAV, INC. AND ITS CONTRIBUTORS “AS IS” AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL SKYNAV, INC. OR ITS CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package com.skynav.ttpe.area;
import org.w3c.dom.Element;
import com.skynav.ttpe.geometry.Point;
import com.skynav.ttpe.style.Visibility;
public class PositionedBlockArea extends BoundedBlockArea {
private Point origin; // allocation rectangle origin
public PositionedBlockArea(Element e, double x, double y, double width, double height, Visibility visibility) {
super(e, width, height, visibility);
this.origin = new Point(x, y);
}
public Point getOrigin() {
return origin;
}
public Point getOrigin(ReferenceRectangle rr) {
if (rr == ReferenceRectangle.ALLOCATION) {
return getOrigin();
} else if (rr == ReferenceRectangle.BORDER) {
return getBorderOrigin();
} else if (rr == ReferenceRectangle.PADDING) {
return getPaddingOrigin();
} else if (rr == ReferenceRectangle.CONTENT) {
return getContentOrigin();
} else if (rr == ReferenceRectangle.CONTAINER) {
throw new UnsupportedOperationException(); // [TBD] IMPLEMENT ME
} else {
throw new IllegalArgumentException();
}
}
public Point getBorderOrigin() { // w.r.t. allocation rectangle origin
return Point.ZERO;
}
public Point getPaddingOrigin() { // w.r.t. allocation rectangle origin
Point borderOrigin = getBorderOrigin();
if (hasBorder()) {
double xBorder = getBorderX();
double yBorder = getBorderY();
return new Point(borderOrigin.getX() + xBorder, borderOrigin.getY() + yBorder);
} else
return borderOrigin;
}
public Point getContentOrigin() { // w.r.t. allocation rectangle origin
Point paddingOrigin = getPaddingOrigin();
if (hasPadding()) {
double xPadding = getPaddingX();
double yPadding = getPaddingY();
return new Point(paddingOrigin.getX() + xPadding, paddingOrigin.getY() + yPadding);
} else
return paddingOrigin;
}
public double getX() {
return getOrigin().getX();
}
public double getY() {
return getOrigin().getY();
}
}