/* * GeoTools - The Open Source Java GIS Toolkit * http://geotools.org * * (C) 2011, Open Source Geospatial Foundation (OSGeo) * (C) 2003-2005, Open Geospatial Consortium Inc. * * All Rights Reserved. http://www.opengis.org/legal/ */ package org.opengis.geometry.coordinate; import org.opengis.geometry.coordinate.Position; import org.opengis.annotation.UML; import static org.opengis.annotation.Obligation.*; import static org.opengis.annotation.Specification.*; /** * A placement defined by linear transformation from the parameter space to the target * coordinate space. In 2-dimensional Cartesian parameter space, (<var>u</var>, <var>v</var>), * transforms into a 3-dimensional coordinate reference system, (<var>x</var>, <var>y</var>, <var>z</var>), * by using an affine transformation, (<var>u</var>, <var>v</var>) → (<var>x</var>, <var>y</var>, <var>z</var>), * which is defined: * * <P><center>(TODO: paste the matrix here)</center></P> * * <P>Then, given this equation, the {@link #getLocation} method returns the direct position * (<var>x</var><sub>0</sub>, <var>y</var><sub>0</sub>, <var>z</var><sub>0</sub>), which * is the target position of the origin in (<var>u</var>, <var>v</var>). The two * {@linkplain #getReferenceDirection reference directions} * (<var>u</var><sub>x</sub>, <var>u</var><sub>y</sub>, <var>u</var><sub>z</sub>) * and (<var>v</var><sub>x</sub>, <var>v</var><sub>y</sub>, <var>v</var><sub>z</sub>) are the * target directions of the unit basis vectors at the origin in (<var>u</var>, <var>v</var>).</P> * * * @source $URL: http://svn.osgeo.org/geotools/trunk/modules/library/opengis/src/main/java/org/opengis/geometry/coordinate/AffinePlacement.java $ * @version <A HREF="http://www.opengeospatial.org/standards/as">ISO 19107</A> * @author Martin Desruisseaux (IRD) * @since GeoAPI 2.0 */ @UML(identifier="GM_AffinePlacement", specification=ISO_19107) public interface AffinePlacement extends Placement { /** * Gives the target of the parameter space origin. This is the vector * (<var>x</var><sub>0</sub>, <var>y</var><sub>0</sub>, <var>z</var><sub>0</sub>) * in the formulae in the class description. */ @UML(identifier="location", obligation=MANDATORY, specification=ISO_19107) Position getLocation(); /** * Gives the target directions for the coordinate basis vectors of the parameter space. * These are the columns of the matrix in the formulae given in the class description. * The number of directions given shall be {@link #getInDimension inDimension}. * The dimension of the directions shall be {@link #getOutDimension outDimension}. * * @param dimension The in dimension, as an index from 0 inclusive to * {@link #getInDimension inDimension} exclusive. * @return The direction as an array of length {@link #getOutDimension outDimension}. */ @UML(identifier="refDirection", obligation=MANDATORY, specification=ISO_19107) double[] getReferenceDirection(int dimension); }