Package org.esa.snap.core.datamodel
Class CrsGeoCoding
- java.lang.Object
- 
- org.esa.snap.core.datamodel.AbstractGeoCoding
- 
- org.esa.snap.core.datamodel.CrsGeoCoding
 
 
- 
- All Implemented Interfaces:
- GeoCoding
 
 public class CrsGeoCoding extends AbstractGeoCoding A geo-coding that is based on a well-known coordinate reference system (CRS) and affine transformation used to locate a product's scene image within the CRS.- Since:
- BEAM 4.7
 
- 
- 
Constructor SummaryConstructors Constructor Description CrsGeoCoding(org.opengis.referencing.crs.CoordinateReferenceSystem mapCRS, int imageWidth, int imageHeight, double easting, double northing, double pixelSizeX, double pixelSizeY)Constructs a new instance of this class from a map CRS, image dimension, and image-to-map transformation parameters.CrsGeoCoding(org.opengis.referencing.crs.CoordinateReferenceSystem mapCRS, int imageWidth, int imageHeight, double easting, double northing, double pixelSizeX, double pixelSizeY, double referencePixelX, double referencePixelY)Constructs a new instance of this class from a map CRS, image dimension, and image-to-map transformation parameters.CrsGeoCoding(org.opengis.referencing.crs.CoordinateReferenceSystem mapCRS, Rectangle imageBounds, AffineTransform imageToMap)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description booleancanGetGeoPos()Checks whether or not this geo-coding can determine the geodetic position from a pixel position.booleancanGetPixelPos()Checks whether or not this geo-coding can determine the pixel position from a geodetic position.voiddispose()Releases all of the resources used by this object instance and all of its owned children.DatumgetDatum()Gets the datum, the reference point or surface against whichGeoPosmeasurements are made.GeoPosgetGeoPos(PixelPos pixelPos, GeoPos geoPos)Returns the latitude and longitude value for a given pixel co-ordinate.org.opengis.referencing.operation.MathTransformgetImageToMapTransform()PixelPosgetPixelPos(GeoPos geoPos, PixelPos pixelPos)Returns the pixel co-ordinates as x/y for a given geographical position given as lat/lon.voidgetPixels(int x1, int y1, int w, int h, double[] latPixels, double[] lonPixels)voidgetPixels(int x1, int y1, int w, int h, float[] latPixels, float[] lonPixels)booleanisCrossingMeridianAt180()Checks whether or not the longitudes of this geo-coding cross the +/- 180 degree meridian.StringtoString()booleantransferGeoCoding(Scene srcScene, Scene destScene, ProductSubsetDef subsetDef)- 
Methods inherited from class org.esa.snap.core.datamodel.AbstractGeoCodingcanClone, clone, createImageCRS, getGeoCRS, getImageCRS, getMapCRS, setGeoCRS, setImageCRS, setMapCRS
 
- 
 
- 
- 
- 
Constructor Detail- 
CrsGeoCodingpublic CrsGeoCoding(org.opengis.referencing.crs.CoordinateReferenceSystem mapCRS, int imageWidth, int imageHeight, double easting, double northing, double pixelSizeX, double pixelSizeY) throws org.opengis.referencing.FactoryException, org.opengis.referencing.operation.TransformExceptionConstructs a new instance of this class from a map CRS, image dimension, and image-to-map transformation parameters. The reference pixel is set to the BEAM default value, namely the center of the upper left image pixel (i.e.referencePixelX = referencePixelY = 0.5).- Parameters:
- mapCRS- the map CRS.
- imageWidth- the width of the image.
- imageHeight- the height of the image.
- easting- the easting of the reference pixel position.
- northing- the northing of the reference pixel position.
- pixelSizeX- the size of a pixel along the x-axis in map units.
- pixelSizeY- the size of a pixel along the y-axis in map units (negative, if positive image Y-axis points up).
- Throws:
- org.opengis.referencing.FactoryException- when an error occurred.
- org.opengis.referencing.operation.TransformException- when an error occurred.
 
 - 
CrsGeoCodingpublic CrsGeoCoding(org.opengis.referencing.crs.CoordinateReferenceSystem mapCRS, int imageWidth, int imageHeight, double easting, double northing, double pixelSizeX, double pixelSizeY, double referencePixelX, double referencePixelY) throws org.opengis.referencing.FactoryException, org.opengis.referencing.operation.TransformExceptionConstructs a new instance of this class from a map CRS, image dimension, and image-to-map transformation parameters.- Parameters:
- mapCRS- the map CRS.
- imageWidth- the width of the image.
- imageHeight- the height of the image.
- easting- the easting of the reference pixel position.
- northing- the northing of the reference pixel position.
- pixelSizeX- the size of a pixel along the x-axis in map units.
- pixelSizeY- the size of a pixel along the y-axis in map units (negative, if positive image Y-axis points up).
- referencePixelX- the x-position of the reference pixel.
- referencePixelY- the y-position of the reference pixel.
- Throws:
- org.opengis.referencing.FactoryException- when an error occurred.
- org.opengis.referencing.operation.TransformException- when an error occurred.
 
 - 
CrsGeoCodingpublic CrsGeoCoding(org.opengis.referencing.crs.CoordinateReferenceSystem mapCRS, Rectangle imageBounds, AffineTransform imageToMap) throws org.opengis.referencing.FactoryException, org.opengis.referencing.operation.TransformException- Throws:
- org.opengis.referencing.FactoryException
- org.opengis.referencing.operation.TransformException
 
 
- 
 - 
Method Detail- 
getImageToMapTransformpublic org.opengis.referencing.operation.MathTransform getImageToMapTransform() - Specified by:
- getImageToMapTransformin interface- GeoCoding
- Overrides:
- getImageToMapTransformin class- AbstractGeoCoding
- Returns:
- The math transformation used to convert image coordinates to map coordinates.
 
 - 
transferGeoCodingpublic boolean transferGeoCoding(Scene srcScene, Scene destScene, ProductSubsetDef subsetDef) Description copied from class:AbstractGeoCoding- Specified by:
- transferGeoCodingin class- AbstractGeoCoding
- Parameters:
- srcScene- the source scene
- destScene- the destination scene
- subsetDef- the definition of the subset, may be- null
- Returns:
- true, if the geo-coding could be transferred.
 
 - 
canGetGeoPospublic boolean canGetGeoPos() Description copied from interface:GeoCodingChecks whether or not this geo-coding can determine the geodetic position from a pixel position.- Returns:
- true, if so
 
 - 
canGetPixelPospublic boolean canGetPixelPos() Description copied from interface:GeoCodingChecks whether or not this geo-coding can determine the pixel position from a geodetic position.- Returns:
- true, if so
 
 - 
disposepublic void dispose() Description copied from interface:GeoCodingReleases all of the resources used by this object instance and all of its owned children. Its primary use is to allow the garbage collector to perform a vanilla job.This method should be called only if it is for sure that this object instance will never be used again. The results of referencing an instance of this class after a call to dispose()are undefined.
 - 
getDatumpublic Datum getDatum() Description copied from interface:GeoCodingGets the datum, the reference point or surface against whichGeoPosmeasurements are made.- Returns:
- the datum
 
 - 
getGeoPospublic GeoPos getGeoPos(PixelPos pixelPos, GeoPos geoPos) Description copied from interface:GeoCodingReturns the latitude and longitude value for a given pixel co-ordinate.- Parameters:
- pixelPos- the pixel's co-ordinates given as x,y
- geoPos- an instance of- GeoPosto be used as return value. If this parameter is- null, the method creates a new instance which it then returns.
- Returns:
- the geographical position as lat/lon in the coordinate system determined by GeoCoding.getGeoCRS()
 
 - 
getPixelPospublic PixelPos getPixelPos(GeoPos geoPos, PixelPos pixelPos) Description copied from interface:GeoCodingReturns the pixel co-ordinates as x/y for a given geographical position given as lat/lon.- Parameters:
- geoPos- the geographical position as lat/lon in the coordinate system determined by- GeoCoding.getGeoCRS()
- pixelPos- an instance of- Pointto be used as return value. If this parameter is- null, the method creates a new instance which it then returns.
- Returns:
- the pixel co-ordinates as x/y
 
 - 
getPixelspublic final void getPixels(int x1, int y1, int w, int h, float[] latPixels, float[] lonPixels)
 - 
getPixelspublic final void getPixels(int x1, int y1, int w, int h, double[] latPixels, double[] lonPixels)
 - 
isCrossingMeridianAt180public boolean isCrossingMeridianAt180() Description copied from interface:GeoCodingChecks whether or not the longitudes of this geo-coding cross the +/- 180 degree meridian.- Returns:
- true, if so
 
 
- 
 
-