All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.orientechnologies.spatial.shape.OShapeOperationImpl Maven / Gradle / Ivy

The newest version!
/**
 * 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); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy