/* * The JTS Topology Suite is a collection of Java classes that * implement the fundamental operations required to validate a given * geo-spatial data set to a known topological specification. * * Copyright (C) 2001 Vivid Solutions * * 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 * * For more information, contact: * * Vivid Solutions * Suite #1A * 2328 Government Street * Victoria BC V8T 5G5 * Canada * * (250)385-6040 * www.vividsolutions.com */ package com.revolsys.geometry.model.impl; import com.revolsys.geometry.model.BoundingBox; import com.revolsys.geometry.model.GeometryFactory; import com.revolsys.geometry.model.Point; /** * Represents a single point. * * A <code>Point</code> is topologically valid if and only if: * <ul> * <li>the coordinate which defines it (if any) is a valid coordinate * (i.e does not have an <code>NaN</code> X or Y ordinate) * </ul> * *@version 1.7 */ public class PointDoubleGf extends PointDouble { private static final long serialVersionUID = 4902022702746614570L; /** * The bounding box of this <code>Geometry</code>. */ private BoundingBox boundingBox; /** * The {@link GeometryFactory} used to create this Geometry */ private final GeometryFactory geometryFactory; /** *@param coordinates contains the single coordinate on which to base this <code>Point</code> * , or <code>null</code> to create the empty geometry. */ public PointDoubleGf(final GeometryFactory geometryFactory, final double... coordinates) { super(geometryFactory, coordinates); this.geometryFactory = geometryFactory; } @Override public int getAxisCount() { return this.geometryFactory.getAxisCount(); } @Override public BoundingBox getBoundingBox() { if (this.boundingBox == null) { if (isEmpty()) { this.boundingBox = getGeometryFactory().newBoundingBoxEmpty(); } else { this.boundingBox = newBoundingBox(); } } return this.boundingBox; } @Override public GeometryFactory getGeometryFactory() { return this.geometryFactory; } @Override public Point move(final double... deltas) { final GeometryFactory geometryFactory = getGeometryFactory(); if (deltas == null || isEmpty()) { return this; } else { final double[] coordinates = getCoordinates(); final int axisCount = Math.min(deltas.length, getAxisCount()); for (int axisIndex = 0; axisIndex < axisCount; axisIndex++) { coordinates[axisIndex] += deltas[axisIndex]; } return geometryFactory.point(coordinates); } } @Override public Point newPoint(final double x, final double y) { final GeometryFactory geometryFactory2 = getGeometryFactory(); return geometryFactory2.point(x, y); } }