/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.
 */

package org.apache.lucene.spatial.spatial4j;

import org.apache.lucene.spatial3d.geom.GeoBBox;
import org.apache.lucene.spatial3d.geom.GeoBBoxFactory;
import org.apache.lucene.spatial3d.geom.GeoPoint;
import org.apache.lucene.spatial3d.geom.GeoPointShapeFactory;
import org.apache.lucene.spatial3d.geom.LatLonBounds;
import org.locationtech.spatial4j.context.SpatialContext;
import org.locationtech.spatial4j.distance.DistanceUtils;
import org.locationtech.spatial4j.shape.Point;
import org.locationtech.spatial4j.shape.Rectangle;
import org.locationtech.spatial4j.shape.Shape;
import org.locationtech.spatial4j.shape.SpatialRelation;

Specialization of a Geo3dShape which represents a Rectangle.
@lucene.experimental
/** * Specialization of a {@link Geo3dShape} which represents a {@link Rectangle}. * * @lucene.experimental */
public class Geo3dRectangleShape extends Geo3dShape<GeoBBox> implements Rectangle { private double minX; private double maxX; private double minY; private double maxY; public Geo3dRectangleShape(final GeoBBox shape, final SpatialContext spatialcontext, double minX, double maxX, double minY, double maxY) { super(shape, spatialcontext); this.minX = minX; this.maxX = maxX; this.minY = minY; this.maxY = maxY; } public Geo3dRectangleShape(final GeoBBox shape, final SpatialContext spatialcontext) { super(shape, spatialcontext); setBoundsFromshape(); }
Set the bounds from the wrapped GeoBBox.
/** * Set the bounds from the wrapped GeoBBox. */
private void setBoundsFromshape() { LatLonBounds bounds = new LatLonBounds(); shape.getBounds(bounds); minX = bounds.checkNoLongitudeBound() ? -180.0 : bounds.getLeftLongitude() * DistanceUtils.RADIANS_TO_DEGREES; minY = bounds.checkNoBottomLatitudeBound() ? -90.0 : bounds.getMinLatitude() * DistanceUtils.RADIANS_TO_DEGREES; maxX = bounds.checkNoLongitudeBound() ? 180.0 : bounds.getRightLongitude() * DistanceUtils.RADIANS_TO_DEGREES; maxY = bounds.checkNoTopLatitudeBound() ? 90.0 : bounds.getMaxLatitude() * DistanceUtils.RADIANS_TO_DEGREES; } @Override public Point getCenter() { Point center = this.center;//volatile read once if (center == null) { GeoPoint point = shape.getCenter(); center = new Geo3dPointShape( GeoPointShapeFactory.makeGeoPointShape(shape.getPlanetModel(), point.getLatitude(), point.getLongitude()), spatialcontext); this.center = center; } return center; } @Override public void reset(double minX, double maxX, double minY, double maxY) { shape = GeoBBoxFactory.makeGeoBBox(shape.getPlanetModel(), maxY * DistanceUtils.DEGREES_TO_RADIANS, minY * DistanceUtils.DEGREES_TO_RADIANS, minX * DistanceUtils.DEGREES_TO_RADIANS, maxX * DistanceUtils.DEGREES_TO_RADIANS); center = null; boundingBox = null; } @Override public Rectangle getBoundingBox() { return this; } @Override public double getWidth() { double result = getMaxX() - getMinX(); if (result < 0) { result += 360; } return result; } @Override public double getHeight() { return getMaxY() - getMinY(); } @Override public double getMinX() { return minX; } @Override public double getMinY() { return minY; } @Override public double getMaxX() { return maxX; } @Override public double getMaxY() { return maxY; } @Override public boolean getCrossesDateLine() { return (getMaxX() > 0 && getMinX() < 0); } @Override public SpatialRelation relateYRange(double minY, double maxY) { Rectangle r = spatialcontext.getShapeFactory().rect(-180, 180, minY, maxY); return relate(r); } @Override public SpatialRelation relateXRange(double minX, double maxX) { Rectangle r = spatialcontext.getShapeFactory().rect(minX, maxX, -90, 90); return relate(r); } @Override public Shape getBuffered(double distance, SpatialContext spatialContext) { GeoBBox bBox = shape.expand(distance * DistanceUtils.DEGREES_TO_RADIANS); return new Geo3dRectangleShape(bBox, spatialContext); } }