/*
* 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);
}
}