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

org.hortonmachine.gears.utils.RegionMap Maven / Gradle / Ivy

There is a newer version: 0.10.8
Show newest version
/*
 * This file is part of HortonMachine (http://www.hortonmachine.org)
 * (C) HydroloGIS - www.hydrologis.com 
 * 
 * The HortonMachine is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see .
 */
package org.hortonmachine.gears.utils;

import static org.hortonmachine.gears.utils.coverage.CoverageUtilities.COLS;
import static org.hortonmachine.gears.utils.coverage.CoverageUtilities.EAST;
import static org.hortonmachine.gears.utils.coverage.CoverageUtilities.NORTH;
import static org.hortonmachine.gears.utils.coverage.CoverageUtilities.ROWS;
import static org.hortonmachine.gears.utils.coverage.CoverageUtilities.SOUTH;
import static org.hortonmachine.gears.utils.coverage.CoverageUtilities.WEST;
import static org.hortonmachine.gears.utils.coverage.CoverageUtilities.XRES;
import static org.hortonmachine.gears.utils.coverage.CoverageUtilities.YRES;

import java.util.HashMap;

import org.hortonmachine.gears.libs.modules.HMConstants;
import org.hortonmachine.gears.utils.coverage.CoverageUtilities;

import org.locationtech.jts.geom.Coordinate;
import org.locationtech.jts.geom.Envelope;

/**
 * Map containing a region definition, having utility methods to get the values.
 * 
 * @author Andrea Antonello (www.hydrologis.com)
 * @since 0.7.2
 */
public class RegionMap extends HashMap {
    private static final long serialVersionUID = 1L;

    /**
     * Getter for the region cols.
     * 
     * @return the region cols or -1.
     */
    public int getCols() {
        Double cols = get(COLS);
        if (cols != null) {
            return cols.intValue();
        }
        return -1;
    }

    /**
     * Getter for the region rows.
     * 
     * @return the region rows or -1.
     */
    public int getRows() {
        Double rows = get(ROWS);
        if (rows != null) {
            return rows.intValue();
        }
        return -1;
    }

    /**
     * Getter for the region's north bound.
     * 
     * @return the region north bound or {@link HMConstants#doubleNovalue}
     */
    public double getNorth() {
        Double n = get(NORTH);
        if (n != null) {
            return n;
        }
        return HMConstants.doubleNovalue;
    }

    /**
     * Getter for the region's south bound.
     * 
     * @return the region south bound or {@link HMConstants#doubleNovalue}
     */
    public double getSouth() {
        Double s = get(SOUTH);
        if (s != null) {
            return s;
        }
        return HMConstants.doubleNovalue;
    }

    /**
     * Getter for the region's east bound.
     * 
     * @return the region east bound or {@link HMConstants#doubleNovalue}
     */
    public double getEast() {
        Double e = get(EAST);
        if (e != null) {
            return e;
        }
        return HMConstants.doubleNovalue;
    }

    /**
     * Getter for the region's west bound.
     * 
     * @return the region west bound or {@link HMConstants#doubleNovalue}
     */
    public double getWest() {
        Double w = get(WEST);
        if (w != null) {
            return w;
        }
        return HMConstants.doubleNovalue;
    }

    /**
     * Getter for the region's X resolution.
     * 
     * @return the region's X resolution or {@link HMConstants#doubleNovalue}
     */
    public double getXres() {
        Double xres = get(XRES);
        if (xres != null) {
            return xres;
        }
        return HMConstants.doubleNovalue;
    }

    /**
     * Getter for the region's Y resolution.
     * 
     * @return the region's Y resolution or {@link HMConstants#doubleNovalue}
     */
    public double getYres() {
        Double yres = get(YRES);
        if (yres != null) {
            return yres;
        }
        return HMConstants.doubleNovalue;
    }

    /**
     * Getter for the region width.
     * 
     * @return the region's width or {@link HMConstants#doubleNovalue}
     */
    public double getWidth() {
        return getEast() - getWest();
    }

    /**
     * Getter for the region height.
     * 
     * @return the region's height or {@link HMConstants#doubleNovalue}
     */
    public double getHeight() {
        return getNorth() - getSouth();
    }

    /**
     * Snaps a geographic point to be on the region grid.
     * 
     * 

* Moves the point given by X and Y to be on the grid of the supplied * region. *

* * @param x the easting of the arbitrary point. * @param y the northing of the arbitrary point. * @return the snapped coordinate. */ public Coordinate snapToNextHigherInRegionResolution( double x, double y ) { double minx = getWest(); double ewres = getXres(); double xsnap = minx + (Math.ceil((x - minx) / ewres) * ewres); double miny = getSouth(); double nsres = getYres(); double ysnap = miny + (Math.ceil((y - miny) / nsres) * nsres); return new Coordinate(xsnap, ysnap); } /** * Create the envelope of the region borders. * * @return the envelope of the region borders. */ public Envelope toEnvelope() { Envelope env = new Envelope(getWest(), getEast(), getSouth(), getNorth()); return env; } /** * Creates a new {@link RegionMap} cropped on the new bounds and snapped on the original grid. * *

The supplied bounds are contained in the resulting region.

* * @param n the new north. * @param s the new south. * @param w the new west. * @param e the new east. * @return the new {@link RegionMap}. */ public RegionMap toSubRegion( double n, double s, double w, double e ) { double originalXres = getXres(); double originalYres = getYres(); double originalWest = getWest(); double originalSouth = getSouth(); double envWest = w; double deltaX = (envWest - originalWest) % originalXres; double newWest = envWest - deltaX; double envSouth = s; double deltaY = (envSouth - originalSouth) % originalYres; double newSouth = envSouth - deltaY; double newWidth = e - w; double deltaW = newWidth % originalXres; newWidth = newWidth - deltaW + originalXres; double newHeight = n - s; double deltaH = newHeight % originalYres; newHeight = newHeight - deltaH + originalYres; double newNorth = newSouth + newHeight; double newEast = newWest + newWidth; int rows = (int) ((newHeight) / originalYres); int cols = (int) ((newWidth) / originalXres); double newXres = (newWidth) / cols; double newYres = (newHeight) / rows; RegionMap regionMap = CoverageUtilities.makeRegionParamsMap(newNorth, newSouth, newWest, newEast, newXres, newYres, cols, rows); return regionMap; } /** * Creates a new {@link RegionMap} cropped on the new bounds and snapped on the original grid. * *

The supplied bounds are contained in the resulting region.

* * @param envelope the envelope to snap. * @return the new {@link RegionMap}. */ public RegionMap toSubRegion( Envelope envelope ) { double w = envelope.getMinX(); double s = envelope.getMinY(); double e = envelope.getMaxX(); double n = envelope.getMaxY(); return toSubRegion(n, s, w, e); } public String toStringJGT() { StringBuilder sb = new StringBuilder(); sb.append("North = ").append(getNorth()).append("\n"); sb.append("South = ").append(getSouth()).append("\n"); sb.append("East = ").append(getEast()).append("\n"); sb.append("West = ").append(getWest()).append("\n"); sb.append("Rows = ").append(getRows()).append("\n"); sb.append("Cols = ").append(getCols()).append("\n"); sb.append("Xres = ").append(getXres()).append("\n"); sb.append("Yres = ").append(getYres()); return sb.toString(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy