/*
* GeoTools - The Open Source Java GIS Toolkit
* http://geotools.org
*
* (C) 2004-2008, Open Source Geospatial Foundation (OSGeo)
*
* 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.geotools.referencing.factory.wms;
// OpenGIS dependencies
import org.opengis.parameter.ParameterValueGroup;
/**
* Auto Equirectangular ({@code AUTO:42004}).
* In the notation below, "<code>${var}</code>" denotes a reference to the value of a variable
* "{@code var}". The variables "{@code lat0}" and "{@code lon0}" are the central point of the
* projection appearing in the CRS parameter of the map request.
*
* <pre>
* PROJCS["WGS 84 / Auto Equirectangular",
* GEOGCS["WGS 84",
* DATUM["WGS_1984",
* SPHEROID["WGS_1984", 6378137, 298.257223563]],
* PRIMEM["Greenwich", 0],
* UNIT["Decimal_Degree", 0.0174532925199433]],
* PROJECTION["Equirectangular"],
* PARAMETER["Latitude_of_Origin", 0],
* PARAMETER["Central_Meridian", ${central_meridian}],
* PARAMETER["Standard_Parallel_1", ${standard_parallel}],
* UNIT["Meter", 1]]
* </pre>
*
* Where:
*
* <pre>
* ${standard_parallel} = ${lat0}
* ${central_meridian} = ${lon0}
* </pre>
*
* @source $URL$
* @version $Id$
* @author Jody Garnett
* @author Rueben Schulz
* @author Martin Desruisseaux
*/
final class Auto42004 extends Factlet {
/**
* A shared (thread-safe) instance.
*/
public static final Auto42004 DEFAULT = new Auto42004();
/**
* Do not allows instantiation except the {@link #DEFAULT} constant.
*/
private Auto42004() {
}
/**
* {@inheritDoc}
*/
public int code() {
return 42004;
}
/**
* {@inheritDoc}
*/
public String getName() {
return "WGS 84 / Auto Equirectangular";
}
/**
* {@inheritDoc}
*/
public String getClassification() {
return "Equidistant_Cylindrical";
}
/**
* {@inheritDoc}
*/
protected void setProjectionParameters(final ParameterValueGroup parameters, final Code code) {
final double centralMeridian = code.longitude;
final double standardParallel1 = code.latitude;
parameters.parameter("central_meridian") .setValue(centralMeridian);
parameters.parameter("latitude_of_origin") .setValue(0.0);
parameters.parameter("standard_parallel_1").setValue(standardParallel1);
}
}