Class AbstractDirectPosition
- All Implemented Interfaces:
- Position,- DirectPosition
- Direct Known Subclasses:
- DirectPosition1D,- GeneralDirectPosition
DirectPosition methods, leaving the data storage to subclasses.
 A direct position holds the coordinates for a position within some
 coordinate reference system.
 This base class provides default implementations for toString(),
 equals(Object) and hashCode() methods.
 This base class does not hold any state and does not implement the Serializable
 or Cloneable interfaces. The internal representation, and the choice to be cloneable or
 serializable, is left to subclasses.
- Since:
- 0.3
Defined in the sis-referencing module
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic AbstractDirectPositioncastOrCopy(DirectPosition position) Returns the given position as anAbstractDirectPositioninstance.booleanReturnstrueif the specified object is also aDirectPositionwith equal coordinates and equal CRS.protected StringFormats this position in the Well Known Text (WKT) format.double[]Returns a sequence of numbers that hold the coordinate of this position in its reference system.Returns the coordinate reference system in which the coordinate tuple is given.final DirectPositionReturns alwaysthis, the direct position for this position.intReturns a hash value for this coordinate tuple.booleanEnsures that the position is contained in the coordinate system domain.voidsetLocation(DirectPosition position) Sets this direct position to the given position.voidsetOrdinate(int dimension, double value) Sets the coordinate value along the specified dimension.Formats this position in the Well Known Text (WKT) format.Methods inherited from class FormattableObjectprint, toString, toWKTMethods inherited from class Objectclone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface DirectPositiongetDimension, getOrdinate
- 
Constructor Details- 
AbstractDirectPositionprotected AbstractDirectPosition()Constructs a direct position.
 
- 
- 
Method Details- 
castOrCopyReturns the given position as anAbstractDirectPositioninstance. If the given position is already an instance ofAbstractDirectPosition, then it is returned unchanged. Otherwise the coordinate values and the CRS of the given position are copied in a new position.- Parameters:
- position- the position to cast, or- null.
- Returns:
- the values of the given position as an AbstractDirectPositioninstance.
- Since:
- 1.0
 
- 
getDirectPositionReturns alwaysthis, the direct position for this position.- Specified by:
- getDirectPositionin interface- Position
- Returns:
- this.
 
- 
getCoordinateReferenceSystemReturns the coordinate reference system in which the coordinate tuple is given. May benullif this particularDirectPositionis included in a larger object with such a reference to a coordinate reference system.The default implementation returns null. Subclasses should override this method if the CRS can be provided.- Specified by:
- getCoordinateReferenceSystemin interface- DirectPosition
- Returns:
- the coordinate reference system, or null.
 
- 
getCoordinatepublic double[] getCoordinate()Returns a sequence of numbers that hold the coordinate of this position in its reference system.- Specified by:
- getCoordinatein interface- DirectPosition
- Returns:
- the coordinates.
 
- 
setOrdinatepublic void setOrdinate(int dimension, double value) Sets the coordinate value along the specified dimension.The default implementation throws UnsupportedOperationException. Subclasses need to override this method if this direct position is mutable.- Specified by:
- setOrdinatein interface- DirectPosition
- Parameters:
- dimension- the dimension for the coordinate of interest.
- value- the coordinate value of interest.
- Throws:
- IndexOutOfBoundsException- if the given index is negative or is equal or greater than the position dimension.
- UnsupportedOperationException- if this direct position is immutable.
 
- 
setLocationpublic void setLocation(DirectPosition position) throws MismatchedDimensionException, MismatchedReferenceSystemException Sets this direct position to the given position. If the given position isnull, then all coordinate values are set toNaN.If this position and the given position have a non-null CRS, then the default implementation requires the CRS to be equals (ignoring metadata), otherwise a MismatchedReferenceSystemExceptionis thrown. However, subclass may choose to assign the CRS of this position to the CRS of the given position.- Parameters:
- position- the new position, or- null.
- Throws:
- MismatchedDimensionException- if the given position doesn't have the expected dimension.
- MismatchedReferenceSystemException- if the given position doesn't use the expected CRS.
 
- 
normalizepublic boolean normalize()Ensures that the position is contained in the coordinate system domain. For each dimension, this method compares the coordinate values against the limits of the coordinate system axis for that dimension. If some coordinates are out of range, then there is a choice depending on the axis range meaning:- If RangeMeaning.EXACT(typically latitudes coordinates), then values greater than the axis maximal value are replaced by the axis maximum, and values smaller than the axis minimal value are replaced by the axis minimum.
- If RangeMeaning.WRAPAROUND(typically longitudes coordinates), then a multiple of the axis range (e.g. 360° for longitudes) is added or subtracted.
 - Returns:
- trueif this position has been modified as a result of this method call, or- falseif no change has been done.
- See Also:
 
- If 
- 
formatToFormats this position in the Well Known Text (WKT) format. The format is like below, wherex₀,x₁,x₂, etc. are the coordinate values at index 0, 1, 2, etc.:
 If the coordinate reference system is geodetic or projected, then coordinate values are formatted with a precision equivalent to one centimetre on Earth (the actual number of fraction digits is adjusted for the axis unit of measurement and the planet size if different than Earth).POINT[x₀ x₁ x₂ …] - Specified by:
- formatToin class- FormattableObject
- Parameters:
- formatter- the formatter where to format the inner content of this point.
- Returns:
- the WKT keyword, which is "Point"for this element.
- Since:
- 1.0
- See Also:
 
- 
toStringFormats this position in the Well Known Text (WKT) format. The returned string is like below, wherex₀,x₁,x₂, etc. are the coordinate values at index 0, 1, 2, etc.:
 This method formats the numbers as withPOINT(x₀ x₁ x₂ …) Double.toString(double)(i.e. without fixed number of fraction digits). The string returned by this method can be parsed by theGeneralDirectPositionconstructor.- Overrides:
- toStringin class- FormattableObject
- Returns:
- this position as a POINTin Well Known Text (WKT) format.
 
- 
hashCodepublic int hashCode()Returns a hash value for this coordinate tuple. This method returns a value compliant with the contract documented in theDirectPosition.hashCode()javadoc. Consequently, it should be possible to mix differentDirectPositionimplementations in the same hash map.- Specified by:
- hashCodein interface- DirectPosition
- Overrides:
- hashCodein class- Object
- Returns:
- a hash code value for this position.
 
- 
equalsReturnstrueif the specified object is also aDirectPositionwith equal coordinates and equal CRS. This method performs the comparison as documented in theDirectPosition.equals(Object)javadoc. In particular, the given object is not required to be of the same implementation class. Consequently, it should be possible to mix differentDirectPositionimplementations in the same hash map.- Specified by:
- equalsin interface- DirectPosition
- Overrides:
- equalsin class- Object
- Parameters:
- object- the object to compare with this position.
- Returns:
- trueif the given object is equal to this position.
 
 
-