com.hazelcast.shaded.org.locationtech.jts.awt.GeometryCollectionShape Maven / Gradle / Ivy
/*
* Copyright (c) 2016 Vivid Solutions.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License 2.0
* and Eclipse Distribution License v. 1.0 which accompanies this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v20.html
* and the Eclipse Distribution License is available at
*
* http://www.eclipse.org/org/documents/edl-v10.php.
*/
package com.hazelcast.shaded.org.locationtech.jts.awt;
import java.awt.Rectangle;
import java.awt.Shape;
import java.awt.geom.AffineTransform;
import java.awt.geom.PathIterator;
import java.awt.geom.Point2D;
import java.awt.geom.Rectangle2D;
import java.util.ArrayList;
import java.util.Iterator;
import com.hazelcast.shaded.org.locationtech.jts.geom.Geometry;
/**
* A {@link Shape} which contains a heterogeneous collection of other shapes
* representing JTS {@link Geometry}s.
*
* @author Martin Davis
*
*/
public class GeometryCollectionShape implements Shape {
private ArrayList shapes = new ArrayList();
public GeometryCollectionShape() {
}
public void add(Shape shape) {
shapes.add(shape);
}
public Rectangle getBounds() {
/**@todo Implement this java.awt.Shape method*/
throw new java.lang.UnsupportedOperationException(
"Method getBounds() not yet implemented.");
}
public Rectangle2D getBounds2D() {
Rectangle2D rectangle = null;
for (Iterator i = shapes.iterator(); i.hasNext();) {
Shape shape = (Shape) i.next();
if (rectangle == null) {
rectangle = shape.getBounds2D();
} else {
rectangle.add(shape.getBounds2D());
}
}
return rectangle;
}
public boolean contains(double x, double y) {
/**@todo Implement this java.awt.Shape method*/
throw new java.lang.UnsupportedOperationException(
"Method contains() not yet implemented.");
}
public boolean contains(Point2D p) {
/**@todo Implement this java.awt.Shape method*/
throw new java.lang.UnsupportedOperationException(
"Method contains() not yet implemented.");
}
public boolean intersects(double x, double y, double w, double h) {
/**@todo Implement this java.awt.Shape method*/
throw new java.lang.UnsupportedOperationException(
"Method intersects() not yet implemented.");
}
public boolean intersects(Rectangle2D r) {
/**@todo Implement this java.awt.Shape method*/
throw new java.lang.UnsupportedOperationException(
"Method intersects() not yet implemented.");
}
public boolean contains(double x, double y, double w, double h) {
/**@todo Implement this java.awt.Shape method*/
throw new java.lang.UnsupportedOperationException(
"Method contains() not yet implemented.");
}
public boolean contains(Rectangle2D r) {
/**@todo Implement this java.awt.Shape method*/
throw new java.lang.UnsupportedOperationException(
"Method contains() not yet implemented.");
}
public PathIterator getPathIterator(AffineTransform at) {
return new ShapeCollectionPathIterator(shapes, at);
}
public PathIterator getPathIterator(AffineTransform at, double flatness) {
// since Geometry is linear, can simply delegate to the simple method
return getPathIterator(at);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy