/*
 * 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.spatial3d.geom;

import java.io.InputStream;
import java.io.OutputStream;
import java.io.IOException;

This GeoBBox represents an area rectangle limited only in south latitude.
@lucene.internal
/** * This GeoBBox represents an area rectangle limited only in south latitude. * * @lucene.internal */
class GeoNorthLatitudeZone extends GeoBaseBBox {
The bottom latitude of the zone
/** The bottom latitude of the zone */
protected final double bottomLat;
Cosine of the bottom latitude of the zone
/** Cosine of the bottom latitude of the zone */
protected final double cosBottomLat;
The bottom plane of the zone
/** The bottom plane of the zone */
protected final SidedPlane bottomPlane;
An interior point of the zone
/** An interior point of the zone */
protected final GeoPoint interiorPoint;
Notable points: none
/** Notable points: none */
protected final static GeoPoint[] planePoints = new GeoPoint[0];
A point on the bottom boundary
/** A point on the bottom boundary */
protected final GeoPoint bottomBoundaryPoint;
A reference to the point on the boundary
/** A reference to the point on the boundary */
protected final GeoPoint[] edgePoints;
Constructor.
Params:
  • planetModel – is the planet model.
  • bottomLat – is the bottom latitude.
/** Constructor. *@param planetModel is the planet model. *@param bottomLat is the bottom latitude. */
public GeoNorthLatitudeZone(final PlanetModel planetModel, final double bottomLat) { super(planetModel); this.bottomLat = bottomLat; final double sinBottomLat = Math.sin(bottomLat); this.cosBottomLat = Math.cos(bottomLat); // Compute an interior point. Pick one whose lat is between top and bottom. final double middleLat = (Math.PI * 0.5 + bottomLat) * 0.5; final double sinMiddleLat = Math.sin(middleLat); this.interiorPoint = new GeoPoint(planetModel, sinMiddleLat, 0.0, Math.sqrt(1.0 - sinMiddleLat * sinMiddleLat), 1.0); this.bottomBoundaryPoint = new GeoPoint(planetModel, sinBottomLat, 0.0, Math.sqrt(1.0 - sinBottomLat * sinBottomLat), 1.0); this.bottomPlane = new SidedPlane(interiorPoint, planetModel, sinBottomLat); this.edgePoints = new GeoPoint[]{bottomBoundaryPoint}; }
Constructor for deserialization.
Params:
  • planetModel – is the planet model.
  • inputStream – is the input stream.
/** * Constructor for deserialization. * @param planetModel is the planet model. * @param inputStream is the input stream. */
public GeoNorthLatitudeZone(final PlanetModel planetModel, final InputStream inputStream) throws IOException { this(planetModel, SerializableObject.readDouble(inputStream)); } @Override public void write(final OutputStream outputStream) throws IOException { SerializableObject.writeDouble(outputStream, bottomLat); } @Override public GeoBBox expand(final double angle) { final double newTopLat = Math.PI * 0.5; final double newBottomLat = bottomLat - angle; return GeoBBoxFactory.makeGeoBBox(planetModel, newTopLat, newBottomLat, -Math.PI, Math.PI); } @Override public boolean isWithin(final double x, final double y, final double z) { return bottomPlane.isWithin(x, y, z); } @Override public double getRadius() { // This is a bit tricky. I guess we should interpret this as meaning the angle of a circle that // would contain all the bounding box points, when starting in the "center". if (bottomLat < 0.0) return Math.PI; double maxCosLat = cosBottomLat; return maxCosLat * Math.PI; } @Override public GeoPoint getCenter() { return interiorPoint; } @Override public GeoPoint[] getEdgePoints() { return edgePoints; } @Override public boolean intersects(final Plane p, final GeoPoint[] notablePoints, final Membership... bounds) { return p.intersects(planetModel, bottomPlane, notablePoints, planePoints, bounds); } @Override public boolean intersects(final GeoShape geoShape) { return geoShape.intersects(bottomPlane, planePoints); } @Override public void getBounds(Bounds bounds) { super.getBounds(bounds); bounds .addHorizontalPlane(planetModel, bottomLat, bottomPlane); } @Override protected double outsideDistance(final DistanceStyle distanceStyle, final double x, final double y, final double z) { return distanceStyle.computeDistance(planetModel, bottomPlane, x,y,z); } @Override public boolean equals(Object o) { if (!(o instanceof GeoNorthLatitudeZone)) return false; GeoNorthLatitudeZone other = (GeoNorthLatitudeZone) o; return super.equals(other) && other.bottomBoundaryPoint.equals(bottomBoundaryPoint); } @Override public int hashCode() { int result = super.hashCode(); result = 31 * result + bottomBoundaryPoint.hashCode(); return result; } @Override public String toString() { return "GeoNorthLatitudeZone: {planetmodel="+planetModel+", bottomlat=" + bottomLat + "(" + bottomLat * 180.0 / Math.PI + ")}"; } }