/*
* Geotoolkit.org - An Open Source Java GIS Toolkit
* http://www.geotoolkit.org
*
* (C) 2010-2012, Open Source Geospatial Foundation (OSGeo)
* (C) 2010-2012, Geomatys
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation;
* version 2.1 of the License.
*
* This library 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
* Lesser General Public License for more details.
*/
package org.geotoolkit.referencing.operation.provider;
import org.opengis.metadata.citation.Citation;
import org.opengis.parameter.ParameterValueGroup;
import org.opengis.parameter.ParameterDescriptor;
import org.opengis.parameter.ParameterDescriptorGroup;
import org.opengis.metadata.Identifier;
import org.opengis.referencing.operation.MathTransform2D;
import org.opengis.referencing.operation.MathTransformFactory;
import org.opengis.referencing.operation.ConicProjection;
import org.apache.sis.internal.referencing.provider.Mercator2SP;
import org.apache.sis.referencing.NamedIdentifier;
import org.geotoolkit.metadata.Citations;
/**
* The provider for "<cite>American Polyconic</cite>" projection (EPSG:9818).
* The math transform implementations instantiated by this provider may be any of the following classes:
* <ul>
* <li>{@link org.geotoolkit.referencing.operation.projection.Polyconic}</li>
* </ul>
*
* <!-- PARAMETERS Polyconic -->
* <p>The following table summarizes the parameters recognized by this provider.
* For a more detailed parameter list, see the {@link #PARAMETERS} constant.</p>
* <blockquote><p><b>Operation name:</b> {@code Polyconic}
* <br><b>Area of use:</b> <font size="-1">(union of CRS domains of validity in EPSG database)</font></p>
* <blockquote><table class="compact">
* <tr><td><b>in latitudes:</b></td><td class="onright">35°42.6′S</td><td>to</td><td class="onright">9°40.2′N</td></tr>
* <tr><td><b>in longitudes:</b></td><td class="onright">83°01.8′W</td><td>to</td><td class="onright">29°01.8′W</td></tr>
* </table></blockquote>
* <table class="geotk">
* <tr><th>Parameter name</th><th>Default value</th></tr>
* <tr><td>{@code semi_major}</td><td></td></tr>
* <tr><td>{@code semi_minor}</td><td></td></tr>
* <tr><td>{@code latitude_of_origin}</td><td>0°</td></tr>
* <tr><td>{@code central_meridian}</td><td>0°</td></tr>
* <tr><td>{@code false_easting}</td><td>0 metres</td></tr>
* <tr><td>{@code false_northing}</td><td>0 metres</td></tr>
* </table></blockquote>
* <!-- END OF PARAMETERS -->
*
* @author Simon Reynard (Geomatys)
* @author Martin Desruisseaux (Geomatys)
* @version 3.20
*
* @see <A HREF="http://www.remotesensing.org/geotiff/proj_list/polyconic.html">Polyconic on RemoteSensing.org</A>
* @see <a href="{@docRoot}/../modules/referencing/operation-parameters.html">Geotk coordinate operations matrix</a>
*
* @since 3.11
* @module
*/
public class Polyconic extends MapProjection {
/**
* For cross-version compatibility.
*/
private static final long serialVersionUID = 1681887819214500096L;
/**
* The group of all parameters expected by this coordinate operation.
* The following table lists the operation names and the parameters recognized by Geotk:
* <p>
* <!-- GENERATED PARAMETERS - inserted by ProjectionParametersJavadoc -->
* <table class="geotk" border="1">
* <tr><th colspan="2">
* <table class="compact">
* <tr><td><b>Name:</b></td><td class="onright"><code>OGC</code>:</td><td class="onleft"><code>Polyconic</code></td></tr>
* <tr><td><b>Alias:</b></td><td class="onright"><code>EPSG</code>:</td><td class="onleft"><code>American Polyconic</code></td></tr>
* <tr><td></td><td class="onright"><code>GeoTIFF</code>:</td><td class="onleft"><code>CT_Polyconic</code></td></tr>
* <tr><td><b>Identifier:</b></td><td class="onright"><code>EPSG</code>:</td><td class="onleft"><code>9818</code></td></tr>
* <tr><td></td><td class="onright"><code>GeoTIFF</code>:</td><td class="onleft"><code>22</code></td></tr>
* </table>
* </th></tr>
* <tr><td>
* <table class="compact">
* <tr><td><b>Name:</b></td><td class="onright"><code>OGC</code>:</td><td class="onleft"><code>semi_major</code></td></tr>
* <tr><td><b>Alias:</b></td><td class="onright"><code>EPSG</code>:</td><td class="onleft"><code>Semi-major axis</code></td></tr>
* <tr><td></td><td class="onright"><code>GeoTIFF</code>:</td><td class="onleft"><code>SemiMajor</code></td></tr>
* </table>
* </td><td>
* <table class="compact">
* <tr><td><b>Type:</b></td><td>{@code Double}</td></tr>
* <tr><td><b>Obligation:</b></td><td>mandatory</td></tr>
* <tr><td><b>Value range:</b></td><td>[0…∞) metres</td></tr>
* </table>
* </td></tr>
* <tr><td>
* <table class="compact">
* <tr><td><b>Name:</b></td><td class="onright"><code>OGC</code>:</td><td class="onleft"><code>semi_minor</code></td></tr>
* <tr><td><b>Alias:</b></td><td class="onright"><code>EPSG</code>:</td><td class="onleft"><code>Semi-minor axis</code></td></tr>
* <tr><td></td><td class="onright"><code>GeoTIFF</code>:</td><td class="onleft"><code>SemiMinor</code></td></tr>
* </table>
* </td><td>
* <table class="compact">
* <tr><td><b>Type:</b></td><td>{@code Double}</td></tr>
* <tr><td><b>Obligation:</b></td><td>mandatory</td></tr>
* <tr><td><b>Value range:</b></td><td>[0…∞) metres</td></tr>
* </table>
* </td></tr>
* <tr><td>
* <table class="compact">
* <tr><td><b>Type:</b></td><td>{@code Boolean}</td></tr>
* <tr><td><b>Obligation:</b></td><td>optional</td></tr>
* <tr><td><b>Default value:</b></td><td>false</td></tr>
* </table>
* </td></tr>
* <tr><td>
* <table class="compact">
* <tr><td><b>Name:</b></td><td class="onright"><code>OGC</code>:</td><td class="onleft"><code>latitude_of_origin</code></td></tr>
* <tr><td><b>Alias:</b></td><td class="onright"><code>EPSG</code>:</td><td class="onleft"><code>Latitude of natural origin</code></td></tr>
* <tr><td></td><td class="onright"><code>GeoTIFF</code>:</td><td class="onleft"><code>NatOriginLat</code></td></tr>
* </table>
* </td><td>
* <table class="compact">
* <tr><td><b>Type:</b></td><td>{@code Double}</td></tr>
* <tr><td><b>Obligation:</b></td><td>mandatory</td></tr>
* <tr><td><b>Value range:</b></td><td>[-90 … 90]°</td></tr>
* <tr><td><b>Default value:</b></td><td>0°</td></tr>
* </table>
* </td></tr>
* <tr><td>
* <table class="compact">
* <tr><td><b>Name:</b></td><td class="onright"><code>OGC</code>:</td><td class="onleft"><code>central_meridian</code></td></tr>
* <tr><td><b>Alias:</b></td><td class="onright"><code>EPSG</code>:</td><td class="onleft"><code>Longitude of natural origin</code></td></tr>
* <tr><td></td><td class="onright"><code>GeoTIFF</code>:</td><td class="onleft"><code>NatOriginLong</code></td></tr>
* </table>
* </td><td>
* <table class="compact">
* <tr><td><b>Type:</b></td><td>{@code Double}</td></tr>
* <tr><td><b>Obligation:</b></td><td>mandatory</td></tr>
* <tr><td><b>Value range:</b></td><td>[-180 … 180]°</td></tr>
* <tr><td><b>Default value:</b></td><td>0°</td></tr>
* </table>
* </td></tr>
* <tr><td>
* <table class="compact">
* <tr><td><b>Name:</b></td><td class="onright"><code>OGC</code>:</td><td class="onleft"><code>false_easting</code></td></tr>
* <tr><td><b>Alias:</b></td><td class="onright"><code>EPSG</code>:</td><td class="onleft"><code>False easting</code></td></tr>
* <tr><td></td><td class="onright"><code>GeoTIFF</code>:</td><td class="onleft"><code>FalseEasting</code></td></tr>
* </table>
* </td><td>
* <table class="compact">
* <tr><td><b>Type:</b></td><td>{@code Double}</td></tr>
* <tr><td><b>Obligation:</b></td><td>mandatory</td></tr>
* <tr><td><b>Value range:</b></td><td>(-∞ … ∞) metres</td></tr>
* <tr><td><b>Default value:</b></td><td>0 metres</td></tr>
* </table>
* </td></tr>
* <tr><td>
* <table class="compact">
* <tr><td><b>Name:</b></td><td class="onright"><code>OGC</code>:</td><td class="onleft"><code>false_northing</code></td></tr>
* <tr><td><b>Alias:</b></td><td class="onright"><code>EPSG</code>:</td><td class="onleft"><code>False northing</code></td></tr>
* <tr><td></td><td class="onright"><code>GeoTIFF</code>:</td><td class="onleft"><code>FalseNorthing</code></td></tr>
* </table>
* </td><td>
* <table class="compact">
* <tr><td><b>Type:</b></td><td>{@code Double}</td></tr>
* <tr><td><b>Obligation:</b></td><td>mandatory</td></tr>
* <tr><td><b>Value range:</b></td><td>(-∞ … ∞) metres</td></tr>
* <tr><td><b>Default value:</b></td><td>0 metres</td></tr>
* </table>
* </td></tr>
* </table>
*/
public static final ParameterDescriptorGroup PARAMETERS;
static {
final Citation[] excludes = {
Citations.ESRI, Citations.NETCDF, Citations.PROJ4
};
PARAMETERS = UniversalParameters.createDescriptorGroup(new Identifier[] {
new NamedIdentifier(Citations.OGC, "Polyconic"),
new NamedIdentifier(Citations.EPSG, "American Polyconic"),
new IdentifierCode (Citations.EPSG, 9818), // The ellipsoidal case
new NamedIdentifier(Citations.GEOTIFF, "CT_Polyconic"),
new IdentifierCode (Citations.GEOTIFF, 22),
new IdentifierCode (Citations.MAP_INFO, 27)
}, excludes, new ParameterDescriptor<?>[] {
SEMI_MAJOR, SEMI_MINOR,
UniversalParameters.LATITUDE_OF_ORIGIN.select(excludes,
"Latitude of natural origin", // EPSG
"latitude_of_origin", // OGC
"NatOriginLat"), // GeoTIFF
UniversalParameters.CENTRAL_MERIDIAN.select(excludes,
"Longitude of natural origin", // EPSG
"central_meridian", // OGC
"NatOriginLong"), // GeoTIFF
(ParameterDescriptor) new Mercator2SP().getParameters().descriptor("scale_factor"), // Not an official parameter, provided for compatibility with those who still use it.
UniversalParameters.FALSE_EASTING.select(excludes,
"False easting", // EPSG
"FalseEasting"), // GeoTIFF
UniversalParameters.FALSE_NORTHING.select(excludes,
"False northing", // EPSG
"FalseNorthing") // GeoTIFF
}, MapProjectionDescriptor.ADD_EARTH_RADIUS);
}
/**
* Constructs a new provider.
*/
public Polyconic() {
super(PARAMETERS);
}
/**
* Returns the operation type for this map projection.
*/
@Override
public Class<ConicProjection> getOperationType() {
return ConicProjection.class;
}
/**
* {@inheritDoc}
*/
@Override
public MathTransform2D createMathTransform(MathTransformFactory factory, ParameterValueGroup values) {
return org.geotoolkit.referencing.operation.projection.Polyconic.create(this, values);
}
}