com.orientechnologies.spatial.shape.OShapeOperationImpl Maven / Gradle / Ivy
Show all versions of orientdb-lucene Show documentation
/**
* Copyright 2010-2016 OrientDB LTD (http://orientdb.com)
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of the License at
*
*
http://www.apache.org/licenses/LICENSE-2.0
*
*
Unless required by applicable law or agreed to in writing, software distributed under the
* License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing permissions and
* limitations under the License.
*
*
For more information: http://www.orientdb.com
*/
package com.orientechnologies.spatial.shape;
import org.locationtech.jts.geom.Geometry;
import org.locationtech.spatial4j.shape.Shape;
import org.locationtech.spatial4j.shape.ShapeCollection;
import org.locationtech.spatial4j.shape.SpatialRelation;
/** Created by Enrico Risa on 29/09/15. */
public class OShapeOperationImpl implements OShapeOperation {
private final OShapeFactory factory;
public OShapeOperationImpl(OShapeFactory oShapeFactory) {
this.factory = oShapeFactory;
}
@Override
public double distance(Shape s1, Shape s2) {
Geometry geometry = factory.toGeometry(s1);
Geometry geometry1 = factory.toGeometry(s2);
return geometry.distance(geometry1);
}
@Override
public boolean isWithInDistance(Shape s1, Shape s2, Double dist) {
Geometry geometry = factory.toGeometry(s1);
Geometry geometry1 = factory.toGeometry(s2);
return geometry.isWithinDistance(geometry1, dist);
}
@Override
public boolean intersect(Shape s1, Shape s2) {
Geometry geometry = factory.toGeometry(s1);
Geometry geometry1 = factory.toGeometry(s2);
return geometry.intersects(geometry1);
}
@Override
public boolean contains(Shape shape, Shape shape1) {
if (shape instanceof ShapeCollection || shape1 instanceof ShapeCollection) {
return shape.relate(shape1).equals(SpatialRelation.CONTAINS);
}
Geometry geometry = factory.toGeometry(shape);
Geometry geometry1 = factory.toGeometry(shape1);
return geometry.contains(geometry1);
}
@Override
public boolean within(Shape shape, Shape shape1) {
if (shape instanceof ShapeCollection || shape1 instanceof ShapeCollection) {
return shape.relate(shape1).equals(SpatialRelation.WITHIN);
}
Geometry geometry = factory.toGeometry(shape);
Geometry geometry1 = factory.toGeometry(shape1);
return geometry.within(geometry1);
}
@Override
public boolean isEquals(Shape shape, Shape shape1) {
return within(shape, shape1) && within(shape1, shape);
}
}