/* * The Unified Mapping Platform (JUMP) is an extensible, interactive GUI * for visualizing and manipulating spatial features with geometry and attributes. * * Copyright (C) 2003 Vivid Solutions * * This program 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 2 * of the License, or (at your option) any later version. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * For more information, contact: * * Vivid Solutions * Suite #1A * 2328 Government Street * Victoria BC V8T 5G5 * Canada * * (250)385-6040 * www.vividsolutions.com */ package com.vividsolutions.jump.workbench.ui.cursortool; import java.awt.geom.NoninvertibleTransformException; import java.util.ArrayList; import java.util.Collection; import java.util.Iterator; import com.vividsolutions.jts.geom.Coordinate; import com.vividsolutions.jts.geom.Envelope; import com.vividsolutions.jts.geom.GeometryFactory; import com.vividsolutions.jts.geom.Polygon; import com.vividsolutions.jump.geom.CoordUtil; public abstract class RectangleTool extends DragTool { public RectangleTool() { } protected Polygon getRectangle() throws NoninvertibleTransformException { Envelope e = new Envelope( getModelSource().x, getModelDestination().x, getModelSource().y, getModelDestination().y); return new GeometryFactory().createPolygon( new GeometryFactory().createLinearRing( new Coordinate[] { new Coordinate(e.getMinX(), e.getMinY()), new Coordinate(e.getMinX(), e.getMaxY()), new Coordinate(e.getMaxX(), e.getMaxY()), new Coordinate(e.getMaxX(), e.getMinY()), new Coordinate(e.getMinX(), e.getMinY())}), null); } private Collection verticesToSnap(Coordinate source, Coordinate destination) { ArrayList verticesToSnap = new ArrayList(); verticesToSnap.add(destination); verticesToSnap.add(new Coordinate(source.x, destination.y)); verticesToSnap.add(new Coordinate(destination.x, source.y)); return verticesToSnap; } protected void setModelDestination(Coordinate modelDestination) { for (Iterator i = verticesToSnap(getModelSource(), modelDestination).iterator(); i.hasNext();) { Coordinate vertex = (Coordinate) i.next(); Coordinate snappedVertex = snap(vertex); if (getSnapManager().wasSnapCoordinateFound()) { this.modelDestination = CoordUtil.add(modelDestination, CoordUtil.subtract(snappedVertex, vertex)); return; } } this.modelDestination = modelDestination; return; } protected void setModelSource(Coordinate modelSource) { this.modelSource = snap(modelSource); } }