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

org.geolatte.geom.crs.CrsId Maven / Gradle / Ivy

Go to download

This geoLatte-geom library offers a geometry model that conforms to the OGC Simple Features for SQL specification.

There is a newer version: 1.9.1
Show newest version
package org.geolatte.geom.crs;

/**
 * An identifier for a CoordinateReferenceSystem or other object referenced in a
 * CoordinateReferenceSystem definition.
 *
 * 

A commonly used alternative name for CrsId is "SRID".

* *

A CrsId consists of the name of an authority and a numeric identifier. The authority is the * organization that is responsible for managing the definition of the identified object.

* *

In practice, CoordinateReferenceSystems are usually identified by their EPSG code, with EPSG * the authority for the identifier. In this implementation, EPSG is the default authority.

* * @author Karel Maesen, Geovise BVBA, 2011 */ public class CrsId { final static public String DEFAULT_AUTHORITY = "EPSG"; /** * Identifies an undefined (or unknown) CrsId. */ final static public CrsId UNDEFINED = new CrsId("EPSG", -1); final private String authority; final private int code; /** * Creates an instance from a String of the form "[:]. * *

If the "authority" prefix is missing, then the authority will be assumed to be EPSG.

* * @param srsString the string to parse into a CrsId. * @return * @throws IllegalArgumentException when the string can nog be parsed as */ static public CrsId parse(String srsString) { if (srsString == null || srsString.isEmpty()) throw new IllegalArgumentException("Require input of form ':"); String[] tokens = srsString.split(":"); String authority; String codeStr = tokens[tokens.length - 1]; int code = toNumericIdentifier(codeStr); authority = DEFAULT_AUTHORITY; if (tokens.length == 2) { authority = tokens[0]; } return valueOf(authority, code); } private static int toNumericIdentifier(String codeStr) { codeStr = codeStr.trim(); try { return Integer.valueOf(codeStr); }catch(NumberFormatException e){ throw new IllegalArgumentException(String.format("Can't parse value %s into an integer.", codeStr)); } } /** * Returns an instance having the specified authority and code. * * @param authority the authority that assigned the code * @param code the code for the CoordinateReferenceSystem * @return a CrsId for the specified authority and code. */ public static CrsId valueOf(String authority, int code) { if (DEFAULT_AUTHORITY.equalsIgnoreCase(authority) && (code <= 0 )) { return CrsId.UNDEFINED; } CrsId result = null; if (DEFAULT_AUTHORITY.equalsIgnoreCase(authority)) { result = CrsRegistry.getCrsIdForEPSG(code); } return result == null ? new CrsId(authority, code) : result; } /** * Returns a CrsId with the specified code and the * EPSG as authority. * * @param code the code for the CrsId. * @return a CrsId for the specified code,and EPSG as authority. */ public static CrsId valueOf(int code) { return valueOf(CrsId.DEFAULT_AUTHORITY, code); } /** * Creates an instance having the specified authority and code. * *

If authority EPSG and 0 or -1 is passed for the code parameter, a value equal to CrsId.UNDEFINED is returned. * * @param authority the authority that assigned the code * @param code the code for the CoordinateReferenceSystem * @return a CrsId for the specified authority and code. */ public CrsId(String authority, int code) { if (authority == null || authority.isEmpty()) { throw new IllegalArgumentException("Null or empty authority parameter."); } this.authority = authority.toUpperCase(); this.code = (code < 1 && DEFAULT_AUTHORITY.equals(this.authority)) ? -1 : code; } /** * Returns the authority for this CrsId. * * @return a String representing the authority for this CrsId */ public String getAuthority() { return authority; } /** * Returns the code for this CrsId. * * @return the numeric code for this CrsId */ public int getCode() { return code; } @Override public String toString() { return String.format("%S:%d", authority, code); } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; CrsId crsId = (CrsId) o; if (code != crsId.code) return false; if (!authority.equals(crsId.authority)) return false; return true; } @Override public int hashCode() { int result = authority.hashCode(); result = 31 * result + code; return result; } }