Class Band
- All Implemented Interfaces:
Extensible,Scaling,SceneTransformProvider
- Direct Known Subclasses:
FilterBand,Mask,VirtualBand
ProductData. The band class is just a
container for attached metadata of the band, currently: - the flag coding
FlagCoding - the band index at which position the band is stored in the associated product
- the center wavelength of the band
- the bandwidth of the band
- the solar spectral flux of the band
- the width and height of the band
The several getPixel and readPixel methods of this class do not necessarily return the
values contained in the data buffer of type ProductData. If the scalingFactor,
scalingOffset or log10Scaled are set a conversion of the form scalingFactor *
rawSample + scalingOffset is applied to the raw samples before the getPixel and @
readPixel methods return the actual pixel values. If the log10Scaled property is true then
the conversion is pow(10, scalingFactor * rawSample + scalingOffset). The several setPixel
and writePixel perform the inverse operations in this case.
- Version:
- $Revision$ $Date$
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class org.esa.snap.core.datamodel.RasterDataNode
RasterDataNode.RasterDataProcessor -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final floatstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final StringFields inherited from class org.esa.snap.core.datamodel.RasterDataNode
INVALID_POS_TEXT, IO_ERROR_TEXT, NO_DATA_TEXT, PROPERTY_NAME_ANCILLARY_RELATIONS, PROPERTY_NAME_ANCILLARY_VARIABLES, PROPERTY_NAME_GEO_CODING, PROPERTY_NAME_IMAGE_INFO, PROPERTY_NAME_IMAGE_TO_MODEL_TRANSFORM, PROPERTY_NAME_LOG_10_SCALED, PROPERTY_NAME_MODEL_TO_SCENE_TRANSFORM, PROPERTY_NAME_NO_DATA_VALUE, PROPERTY_NAME_NO_DATA_VALUE_USED, PROPERTY_NAME_SCALING_FACTOR, PROPERTY_NAME_SCALING_OFFSET, PROPERTY_NAME_SCENE_TO_MODEL_TRANSFORM, PROPERTY_NAME_STX, PROPERTY_NAME_TIME_CODING, PROPERTY_NAME_VALID_PIXEL_EXPRESSIONFields inherited from class org.esa.snap.core.datamodel.DataNode
PROPERTY_NAME_DATA, PROPERTY_NAME_READ_ONLY, PROPERTY_NAME_SYNTHETIC, PROPERTY_NAME_UNITFields inherited from class org.esa.snap.core.datamodel.ProductNode
PROPERTY_NAME_DESCRIPTION, PROPERTY_NAME_NAME -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidacceptVisitor(ProductVisitor visitor) Accepts the given visitor.protected StxcomputeStxImpl(int level, ProgressMonitor pm) Computes the statistics.createDefaultImageInfo(double[] histoSkipAreas, ProgressMonitor pm) Creates a default image information instance.protected RenderedImageCreates the source image associated with thisRasterDataNode.voiddispose()Releases all of the resources used by this object instance and all of its owned children.intfloatgetDate()Gets the date.intGets the (zero-based) date band index.Gets the flag coding for this band.Gets the index coding for this band.longgetRawStorageSize(ProductSubsetDef subsetDef) Gets an estimated raw storage size in bytes of this product node.Gets the sample coding.floatGets the solar flux inmW/(m^2 nm)(milli-watts per square metre per nanometer) units for the wavelength of this band.intGets the (zero-based) spectral band index.floatGets the spectral bandwidth innm(nanomater) units.floatGets the spectral wavelength innm(nanometer) units.booleanTests whether or not this band is a flag band (getFlagCoding() != null).booleanTests whether or not this band is an index band (getIndexCoding() != null).booleanvoidreadRasterData(int offsetX, int offsetY, int width, int height, ProductData rasterData, ProgressMonitor pm) Reads raster data from its associated data source into the given data buffer.voidReads the complete underlying raster data.voidremoveFromFile(ProductWriter productWriter) Physically remove this node from the file associated with the given product writer.voidsetAngularBandIndex(int angularBandIndex) voidsetAngularValue(float angularValue) voidSets the date.voidsetDateBandIndex(int dateBandIndex) Sets the (zero-based) date band index.voidsetSampleCoding(SampleCoding sampleCoding) Sets the sample coding for this band.voidsetSolarFlux(float solarFlux) Sets the solar flux inmW/(m^2 nm)(milli-watts per square metre per nanometer) units for the wavelength of this band.voidsetSpectralBandIndex(int spectralBandIndex) Sets the (zero-based) spectral band index.voidsetSpectralBandwidth(float spectralBandwidth) Sets the spectral bandwidth innm(nanomater) units.voidsetSpectralWavelength(float spectralWavelength) Sets the spectral wavelength innm(nanomater) units.toString()Creates a string defining this band object.voidwriteRasterData(int offsetX, int offsetY, int width, int height, ProductData rasterData, ProgressMonitor pm) Writes data from this product raster into the specified region of the user-supplied raster.voidWrites the complete underlying raster data.Methods inherited from class org.esa.snap.core.datamodel.AbstractBand
ensureMinLengthArray, ensureMinLengthArray, ensureMinLengthArray, ensureRasterData, getPixelDouble, getPixelFloat, getPixelInt, getPixels, getPixels, getPixels, getRasterHeight, getRasterWidth, loadRasterData, readPixels, readPixels, readPixels, setPixelDouble, setPixelFloat, setPixelInt, setPixels, setPixels, setPixels, unloadRasterData, writePixels, writePixels, writePixelsMethods inherited from class org.esa.snap.core.datamodel.RasterDataNode
addAncillaryVariable, canBeOrthorectified, checkCompatibleRasterData, clearNoDataValue, createColorIndexedImage, createCompatibleRasterData, createCompatibleRasterData, createCompatibleSceneRasterData, createDefaultImageInfo, createMultiLevelModel, createPointing, createRgbImage, createTransectProfileData, fireImageInfoChanged, getAncillaryRelations, getAncillaryVariable, getAncillaryVariables, getGeoCoding, getGeophysicalDataType, getGeophysicalImage, getGeophysicalNoDataValue, getImageInfo, getImageInfo, getImageInfo, getImageToModelTransform, getModelToSceneTransform, getMultiLevelModel, getNoDataValue, getOverlayMaskGroup, getPixels, getPixels, getPixelString, getPointing, getRasterData, getRasterSize, getSampleFloat, getSampleInt, getScalingFactor, getScalingOffset, getSceneToModelTransform, getSourceImage, getStx, getStx, getTimeCoding, getValidMaskExpression, getValidMaskImage, getValidPixelExpression, getValidShape, hasGeoCoding, hasIntPixels, hasRasterData, isCompatibleRasterData, isFloatingPointType, isGeophysicalImageSet, isLog10Scaled, isNoDataValueSet, isNoDataValueUsed, isPixelValid, isPixelValid, isPixelValid, isPixelWithinImageBounds, isScalingApplied, isSourceImageSet, isStxSet, isValidMaskImageSet, isValidMaskProperty, isValidMaskUsed, loadRasterData, processRasterData, quantizeRasterData, quantizeRasterData, readPixels, readPixels, readPixels, readRasterData, readRasterDataFully, readValidMask, removeAncillaryVariable, removeCachedImageData, resetValidMask, scale, scaleInverse, setAncillaryRelations, setGeoCoding, setGeophysicalNoDataValue, setImageInfo, setImageInfo, setImageToModelTransform, setLog10Scaled, setModelToSceneTransform, setModified, setNoDataValue, setNoDataValueUsed, setRasterData, setScalingFactor, setScalingOffset, setSceneToModelTransform, setSourceImage, setSourceImage, setStx, setTimeCoding, setValidPixelExpression, updateExpression, writePixels, writePixels, writePixels, writeRasterData, writeRasterDataFullyMethods inherited from class org.esa.snap.core.datamodel.DataNode
checkDataCompatibility, createCompatibleProductData, fireProductNodeDataChanged, getData, getDataElems, getDataElemSize, getDataType, getNumDataElems, getUnit, isReadOnly, isSynthetic, setData, setDataElems, setReadOnly, setSynthetic, setUnitMethods inherited from class org.esa.snap.core.datamodel.ProductNode
fireProductNodeChanged, fireProductNodeChanged, getDescription, getDisplayName, getName, getOwner, getProduct, getProductReader, getProductReaderSafe, getProductRefString, getProductSafe, getProductWriter, getProductWriterSafe, getRawStorageSize, isModified, isPartOfSubset, isValidNodeName, setDescription, setName, setNodeName, setOwnerMethods inherited from class com.bc.ceres.core.ExtensibleObject
getExtension
-
Field Details
-
PROPERTY_NAME_SAMPLE_CODING
- See Also:
-
PROPERTY_NAME_SOLAR_FLUX
- See Also:
-
PROPERTY_NAME_SPECTRAL_BAND_INDEX
- See Also:
-
PROPERTY_NAME_SPECTRAL_BANDWIDTH
- See Also:
-
PROPERTY_NAME_SPECTRAL_WAVELENGTH
- See Also:
-
PROPERTY_NAME_DATE_BAND_INDEX
- See Also:
-
PROPERTY_NAME_DATE
- See Also:
-
PROPERTY_NAME_ANGULAR_BAND_INDEX
- See Also:
-
PROPERTY_NAME_ANGULAR_VALUE
- See Also:
-
ANGULAR_VIEW_NULL_VALUE
public static final float ANGULAR_VIEW_NULL_VALUE- See Also:
-
-
Constructor Details
-
Band
Constructs a newBand.- Parameters:
name- the name of the new objectdataType- the raster data type, must be one of the multipleProductData.TYPE_Xconstants, with the exception ofProductData.TYPE_UINT32width- the width of the raster in pixelsheight- the height of the raster in pixels
-
-
Method Details
-
getFlagCoding
Gets the flag coding for this band.- Returns:
- a non-null value if this band is a flag dataset,
nullotherwise
-
isFlagBand
public boolean isFlagBand()Tests whether or not this band is a flag band (getFlagCoding() != null).- Returns:
trueif so
-
getIndexCoding
Gets the index coding for this band.- Returns:
- a non-null value if this band is a flag dataset,
nullotherwise
-
isIndexBand
public boolean isIndexBand()Tests whether or not this band is an index band (getIndexCoding() != null).- Returns:
trueif so
-
getSampleCoding
Gets the sample coding.- Returns:
- the sample coding, or
nullif not set.
-
setSampleCoding
Sets the sample coding for this band.- Parameters:
sampleCoding- the sample coding- Throws:
IllegalArgumentException- if this band does not contain integer pixels
-
getAngularValue
public float getAngularValue() -
setAngularValue
public void setAngularValue(float angularValue) -
getAngularBandIndex
public int getAngularBandIndex() -
setAngularBandIndex
public void setAngularBandIndex(int angularBandIndex) -
getSpectralBandIndex
public int getSpectralBandIndex()Gets the (zero-based) spectral band index.- Returns:
- the (zero-based) spectral band index or
-1if it is unknown
-
setSpectralBandIndex
public void setSpectralBandIndex(int spectralBandIndex) Sets the (zero-based) spectral band index.- Parameters:
spectralBandIndex- the (zero-based) spectral band index or-1if it is unknown
-
getSpectralWavelength
public float getSpectralWavelength()Gets the spectral wavelength innm(nanometer) units.- Returns:
- the wave length in nanometers of this band, or zero if this is not a spectral band or the wave length is not known.
-
setSpectralWavelength
public void setSpectralWavelength(float spectralWavelength) Sets the spectral wavelength innm(nanomater) units.- Parameters:
spectralWavelength- the wavelength in nanometers of this band, or zero if this is not a spectral band or the wavelength is not known.
-
getDateBandIndex
public int getDateBandIndex()Gets the (zero-based) date band index.- Returns:
- the (zero-based) date band index or
-1if it is unknown
-
setDateBandIndex
public void setDateBandIndex(int dateBandIndex) Sets the (zero-based) date band index.- Parameters:
dateBandIndex- the (zero-based) spectral band index or-1if it is unknown
-
getDate
Gets the date.- Returns:
- the date for this band, or zero if this is not a date band or the date is not known.
-
setDate
Sets the date.- Parameters:
date- YYYY-MM-DD of this band, or 1601-01-01 if this is not a date band or the date is not known.
-
getSpectralBandwidth
public float getSpectralBandwidth()Gets the spectral bandwidth innm(nanomater) units.- Returns:
- the bandwidth in nanometers of this band, or zero if this is not a spectral band or the bandwidth is not known.
-
setSpectralBandwidth
public void setSpectralBandwidth(float spectralBandwidth) Sets the spectral bandwidth innm(nanomater) units.- Parameters:
spectralBandwidth- the spectral bandwidth in nanometers of this band, or zero if this is not a spectral band or the spectral bandwidth is not known.
-
getSolarFlux
public float getSolarFlux()Gets the solar flux inmW/(m^2 nm)(milli-watts per square metre per nanometer) units for the wavelength of this band.- Returns:
- the solar flux for the wavelength of this band, or zero if this is not a spectral band or the solar flux is not known.
-
setSolarFlux
public void setSolarFlux(float solarFlux) Sets the solar flux inmW/(m^2 nm)(milli-watts per square metre per nanometer) units for the wavelength of this band.- Parameters:
solarFlux- the solar flux for the wavelength of this band, or zero if this is not a spectral band or the solar flux is not known.
-
createSourceImage
Description copied from class:RasterDataNodeCreates the source image associated with thisRasterDataNode. This shall preferably be aMultiLevelImageinstance which recognises this raster data node'simageToModelTransformproperty, if set.- Specified by:
createSourceImagein classRasterDataNode- Returns:
- A new source image instance.
-
readRasterData
public void readRasterData(int offsetX, int offsetY, int width, int height, ProductData rasterData, ProgressMonitor pm) throws IOException Reads raster data from its associated data source into the given data buffer.- Specified by:
readRasterDatain classRasterDataNode- Parameters:
offsetX- the X-offset in the band's pixel co-ordinates where reading startsoffsetY- the Y-offset in the band's pixel co-ordinates where reading startswidth- the width of the raster data bufferheight- the height of the raster data bufferrasterData- a raster data buffer receiving the pixels to be readpm- a monitor to inform the user about progress- Throws:
IOException- if an I/O error occursIllegalArgumentException- if the raster is nullIllegalStateException- if this product raster was not added to a product so far, or if the product to which this product raster belongs to, has no associated product reader- See Also:
-
isProductReaderDirectlyUsable
public boolean isProductReaderDirectlyUsable() -
readRasterDataFully
Reads the complete underlying raster data.After this method has been called successfully,
hasRasterData()should always returntrueandgetRasterData()should always return a validProductDatainstance with at leastgetRasterWidth()*getRasterHeight()elements (samples).In opposite to the
loadRasterDatamethod, thereadRasterDataFullymethod always reloads the data of this product raster, independently of whether its has already been loaded or not.- Specified by:
readRasterDataFullyin classRasterDataNode- Parameters:
pm- a monitor to inform the user about progress- Throws:
IOException- if an I/O error occurs- See Also:
-
writeRasterData
public void writeRasterData(int offsetX, int offsetY, int width, int height, ProductData rasterData, ProgressMonitor pm) throws IOException Writes data from this product raster into the specified region of the user-supplied raster.It is important to know that this method does not change this product raster's internal state nor does it write into this product raster's internal raster.
- Specified by:
writeRasterDatain classRasterDataNode- Parameters:
offsetX- the X-offset in raster co-ordinates where reading startsoffsetY- the Y-offset in raster co-ordinates where reading startswidth- the width of the raster data bufferheight- the height of the raster data bufferrasterData- a raster data buffer receiving the pixels to be readpm- a monitor to inform the user about progress- Throws:
IOException- if an I/O error occurs- See Also:
-
writeRasterDataFully
Writes the complete underlying raster data.- Specified by:
writeRasterDataFullyin classRasterDataNode- Parameters:
pm- a monitor to inform the user about progress- Throws:
IOException- if an I/O error occurs
-
getRawStorageSize
Gets an estimated raw storage size in bytes of this product node.- Specified by:
getRawStorageSizein classAbstractBand- Parameters:
subsetDef- if notnullthe subset may limit the size returned- Returns:
- the size in bytes.
-
acceptVisitor
Accepts the given visitor. This method implements the well known 'Visitor' design pattern of the gang-of-four. The visitor pattern allows to define new operations on the product data model without the need to add more code to it. The new operation is implemented by the visitor.The method simply calls
visitor.visit(this).- Specified by:
acceptVisitorin classRasterDataNode- Parameters:
visitor- the visitor, must not benull
-
toString
Creates a string defining this band object.- Overrides:
toStringin classProductNode
-
removeFromFile
Description copied from class:ProductNodePhysically remove this node from the file associated with the given product writer. The default implementation does nothing.- Overrides:
removeFromFilein classProductNode- Parameters:
productWriter- the product writer to be used to remove this node from the underlying file.
-
createDefaultImageInfo
Description copied from class:RasterDataNodeCreates a default image information instance.An
IllegalStateExceptionis thrown in the case that this raster data node has no raster data.- Overrides:
createDefaultImageInfoin classRasterDataNode- Parameters:
histoSkipAreas- the left (at index 0) and right (at index 1) normalized areas of the raster data histogram to be excluded when determining the value range for a linear constrast stretching. Can benull, in this case{0.01, 0.04}resp. 5% of the entire area is skipped.pm- a monitor to inform the user about progress- Returns:
- a valid image information instance, never
null.
-
computeStxImpl
Description copied from class:RasterDataNodeComputes the statistics. May be overridden. This method belongs to preliminary API and may be removed or changed in the future.- Overrides:
computeStxImplin classRasterDataNode- Parameters:
level- The resolution level.pm- A progress monitor.- Returns:
- The statistics.
-
dispose
public void dispose()Releases 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.Overrides of this method should always call
super.dispose();after disposing this instance.- Overrides:
disposein classRasterDataNode
-