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

org.jxmapviewer.viewer.GeoBounds Maven / Gradle / Ivy

There is a newer version: 1.7.8
Show newest version
package org.jxmapviewer.viewer;

import java.awt.geom.Rectangle2D;
import java.util.Set;

/**
 * The GeoBounds class provides access the the North East and South West corners of the bounds and provides
 * an intersects method.
 * @author Dan Andrews
 */
public class GeoBounds
{

    /** Internal representation of the bounds */
    private Rectangle2D[] rects;

    /**
     * Constructor.
     * @param minLat The minimum latitude.
     * @param minLng The minimum longitude.
     * @param maxLat The maximum latitude.
     * @param maxLng The maximum longitude.
     */
    public GeoBounds(double minLat, double minLng, double maxLat, double maxLng)
    {
        setRect(minLat, minLng, maxLat, maxLng);
    }

    /**
     * Constructor.
     * @param geoPositions A non null list of 2 or more different GeoBounds objects.
     */
    public GeoBounds(Set geoPositions)
    {
        if (geoPositions == null || geoPositions.size() == 0)
        {
            throw new IllegalArgumentException("The attribute 'geoPositions' cannot be null and must "
                    + "have 1 or more elements.");
        }
        double minLat = Integer.MAX_VALUE;
        double minLng = Integer.MAX_VALUE;
        double maxLat = Integer.MIN_VALUE;
        double maxLng = Integer.MIN_VALUE;
        for (GeoPosition position : geoPositions)
        {
            minLat = Math.min(minLat, position.getLatitude());
            minLng = Math.min(minLng, position.getLongitude());
            maxLat = Math.max(maxLat, position.getLatitude());
            maxLng = Math.max(maxLng, position.getLongitude());
        }
        setRect(minLat, minLng, maxLat, maxLng);
    }

    /**
     * Sets the internal rectangle representation.
     * @param minLat The minimum latitude.
     * @param minLng The minimum longitude.
     * @param maxLat The maximum latitude.
     * @param maxLng The maximum longitude.
     */
    private void setRect(double minLat, double minLng, double maxLat, double maxLng)
    {
        if (minLat > maxLat)
        {
            throw new IllegalArgumentException("GeoBounds is not valid - minLat must be less than or equal maxLat.");
        }
        if (minLng > maxLng)
        {
            if (minLng > 0 && minLng < 180 && maxLng < 0)
            {
                rects = new Rectangle2D[] {
                        // split into two rects e.g. 176.8793 to 180 and -180 to
                        // -175.0104
                        new Rectangle2D.Double(minLng, minLat, 180 - minLng, maxLat - minLat),
                        new Rectangle2D.Double(-180, minLat, maxLng + 180, maxLat - minLat) };
            }
            else
            {
                rects = new Rectangle2D[] { new Rectangle2D.Double(minLng, minLat, maxLng - minLng, maxLat - minLat) };

                throw new IllegalArgumentException("GeoBounds is not valid - minLng must be less than or equal maxLng or "
                        + "minLng must be greater than 0 and maxLng must be less than 0.");
            }
        }
        else
        {
            rects = new Rectangle2D[] { new Rectangle2D.Double(minLng, minLat, maxLng - minLng, maxLat - minLat) };
        }
    }

    /**
     * Determines if this bounds intersects the other bounds.
     * @param other The other bounds to test for intersection with.
     * @return Returns true if bounds intersect.
     */
    public boolean intersects(GeoBounds other)
    {
        boolean rv = false;
        for (Rectangle2D r1 : rects)
        {
            for (Rectangle2D r2 : other.rects)
            {
                rv = r1.intersects(r2);
                if (rv)
                {
                    break;
                }
            }
            if (rv)
            {
                break;
            }

        }
        return rv;
    }

    /**
     * Gets the north west position.
     * @return Returns the north west position.
     */
    public GeoPosition getNorthWest()
    {
        return new GeoPosition(rects[0].getMaxY(), rects[0].getX());
    }

    /**
     * Gets the south east position.
     * @return Returns the south east position.
     */
    public GeoPosition getSouthEast()
    {
        Rectangle2D r = rects[0];
        if (rects.length > 1)
        {
            r = rects[1];
        }
        return new GeoPosition(r.getY(), r.getMaxX());
    }

    /**
     * @return the center of the bounds
     */
    public GeoPosition getCenter() {
        GeoPosition nw = getNorthWest();
        GeoPosition se = getSouthEast();
        double lat = (nw.getLatitude() + se.getLatitude()) * 0.5;
        double lon = (nw.getLongitude() + se.getLongitude()) * 0.5;
        return new GeoPosition(lat, lon);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy