All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sourceforge.plantuml.geom.Box Maven / Gradle / Ivy

Go to download

PlantUML is a component that allows to quickly write : * sequence diagram, * use case diagram, * class diagram, * activity diagram, * component diagram, * state diagram * object diagram

There is a newer version: 8059
Show newest version
/* ========================================================================
 * PlantUML : a free UML diagram generator
 * ========================================================================
 *
 * (C) Copyright 2009-2013, Arnaud Roques
 *
 * Project Info:  http://plantuml.sourceforge.net
 * 
 * This file is part of PlantUML.
 *
 * PlantUML is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * PlantUML 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 General Public
 * License for more details.
 *
 * You should have received a copy of the GNU General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301,
 * USA.
 *
 * [Java is a trademark or registered trademark of Sun Microsystems, Inc.
 * in the United States and other countries.]
 *
 * Original Author:  Arnaud Roques
 * 
 * Revision $Revision: 9786 $
 *
 */
package net.sourceforge.plantuml.geom;

public class Box implements XMoveable, Pointable {

	private int x;
	private int y;
	final private int width;
	final private int height;

	public Box(int x, int y, int width, int height) {
		if (width <= 0 || height <= 0) {
			throw new IllegalArgumentException();
		}
		this.x = x;
		this.y = y;
		this.width = width;
		this.height = height;
	}

	@Override
	public String toString() {
		return "Box [" + x + "," + y + "] " + width + "," + height;
	}

	public Point2DInt[] getCorners() {
		final Point2DInt p1 = new Point2DInt(getX(), getY());
		final Point2DInt p2 = new Point2DInt(getX() + getWidth(), getY());
		final Point2DInt p3 = new Point2DInt(getX() + getWidth(), getY() + getHeight());
		final Point2DInt p4 = new Point2DInt(getX(), getY() + getHeight());
		return new Point2DInt[] { p1, p2, p3, p4 };
	}

	public Point2DInt[] getCornersOfOneSide(LineSegmentInt seg, int sgn) {
		final Point2DInt[] corners = getCorners();
		final double sgn0 = seg.side(corners[0]);
		final double sgn1 = seg.side(corners[1]);
		final double sgn2 = seg.side(corners[2]);
		final double sgn3 = seg.side(corners[3]);
		int nb = 0;
		if (Math.signum(sgn0) == sgn) {
			nb++;
		}
		if (Math.signum(sgn1) == sgn) {
			nb++;
		}
		if (Math.signum(sgn2) == sgn) {
			nb++;
		}
		if (Math.signum(sgn3) == sgn) {
			nb++;
		}
		final Point2DInt[] result = new Point2DInt[nb];
		int i = 0;
		if (Math.signum(sgn0) == sgn) {
			result[i++] = corners[0];
		}
		if (Math.signum(sgn1) == sgn) {
			result[i++] = corners[1];
		}
		if (Math.signum(sgn2) == sgn) {
			result[i++] = corners[2];
		}
		if (Math.signum(sgn3) == sgn) {
			result[i++] = corners[3];
		}
		assert nb == i;
		return result;
	}

	public boolean doesIntersect(LineSegmentInt seg) {
		return intersect(seg).length > 0;
	}

	public Point2DInt[] intersect(LineSegmentInt seg) {
		if (seg.side(this) != 0) {
			return new Point2DInt[0];
		}
		// Log.println("THIS=" + this);
		// Log.println("LineSegment=" + seg);
		final Point2DInt corners[] = getCorners();
		final LineSegmentInt seg1 = new LineSegmentInt(corners[0], corners[1]);
		final LineSegmentInt seg2 = new LineSegmentInt(corners[1], corners[2]);
		final LineSegmentInt seg3 = new LineSegmentInt(corners[2], corners[3]);
		final LineSegmentInt seg4 = new LineSegmentInt(corners[3], corners[0]);
		final Point2DInt i1 = seg.getSegIntersection(seg1);
		Point2DInt i2 = seg.getSegIntersection(seg2);
		Point2DInt i3 = seg.getSegIntersection(seg3);
		Point2DInt i4 = seg.getSegIntersection(seg4);

		// Log.println("i1="+i1);
		// Log.println("i2="+i2);
		// Log.println("i3="+i3);
		// Log.println("i4="+i4);

		if (i2 != null && i2.equals(i1)) {
			i2 = null;
		}
		if (i3 != null && (i3.equals(i1) || i3.equals(i2))) {
			i3 = null;
		}
		if (i4 != null && (i4.equals(i1) || i4.equals(i2) || i4.equals(i3))) {
			i4 = null;
		}

		final int nb = countNotNull(i1, i2, i3, i4);
		assert nb >= 0 && nb <= 3 : nb;
		int i = 0;
		final Point2DInt result[] = new Point2DInt[nb];
		if (i1 != null) {
			result[i++] = i1;
		}
		if (i2 != null) {
			result[i++] = i2;
		}
		if (i3 != null) {
			result[i++] = i3;
		}
		if (i4 != null) {
			result[i++] = i4;
		}
		assert i == nb;
		assert getCornersOfOneSide(seg, 0).length + getCornersOfOneSide(seg, 1).length
				+ getCornersOfOneSide(seg, -1).length == 4;
		return result;
	}

	private int countNotNull(Point2DInt i1, Point2DInt i2, Point2DInt i3, Point2DInt i4) {
		int n = 0;
		if (i1 != null) {
			n++;
		}
		if (i2 != null) {
			n++;
		}
		if (i3 != null) {
			n++;
		}
		if (i4 != null) {
			n++;
		}
		return n;
	}

	public Box outerBox(int margin) {
		return new Box(x - margin, y - margin, width + 2 * margin, height + 2 * margin);
	}

	public Point2DInt getCenterPoint() {
		return new Point2DInt(x + width / 2, y + height / 2);
	}

	public void moveX(int delta) {
		this.x += delta;
	}

	public boolean intersectBox(Box other) {
		return other.x + other.width > this.x && other.y + other.height > this.y && other.x < this.x + this.width
				&& other.y < this.y + this.height;
	}

	public final int getX() {
		return x;
	}

	public final int getY() {
		return y;
	}

	public final int getWidth() {
		return width;
	}

	public final int getHeight() {
		return height;
	}

	public int getMinX() {
		return x;
	}

	public int getMinY() {
		return y;
	}

	public int getMaxX() {
		return x + width;
	}

	public int getMaxY() {
		return y + height;
	}

	public int getCenterX() {
		return x + width / 2;
	}

	public int getCenterY() {
		return y + height / 2;
	}

	public Point2DInt getPosition() {
		return getCenterPoint();
	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy