geotrellis.raster.io.geotiff.Float32GeoTiffMultibandTile.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of geotrellis-raster_2.11 Show documentation
Show all versions of geotrellis-raster_2.11 Show documentation
GeoTrellis is an open source geographic data processing engine for high performance applications.
The newest version!
package geotrellis.raster.io.geotiff
import geotrellis.raster._
import geotrellis.raster.io.geotiff.compression._
import java.nio.ByteBuffer
class Float32GeoTiffMultibandTile(
compressedBytes: Array[Array[Byte]],
decompressor: Decompressor,
segmentLayout: GeoTiffSegmentLayout,
compression: Compression,
bandCount: Int,
hasPixelInterleave: Boolean,
val cellType: FloatCells with NoDataHandling
) extends GeoTiffMultibandTile(compressedBytes, decompressor, segmentLayout, compression, bandCount, hasPixelInterleave)
with Float32GeoTiffSegmentCollection {
val noDataValue: Option[Float] = cellType match {
case FloatCellType => None
case FloatConstantNoDataCellType => Some(Float.NaN)
case FloatUserDefinedNoDataCellType(nd) => Some(nd)
}
protected def createSegmentCombiner(targetSize: Int): SegmentCombiner =
new SegmentCombiner(bandCount) {
private val arr = Array.ofDim[Float](targetSize)
def set(targetIndex: Int, v: Int): Unit = {
arr(targetIndex) = i2f(v)
}
def setDouble(targetIndex: Int, v: Double): Unit = {
arr(targetIndex) = d2f(v)
}
def getBytes(): Array[Byte] = {
val result = new Array[Byte](targetSize * FloatConstantNoDataCellType.bytes)
val bytebuff = ByteBuffer.wrap(result)
bytebuff.asFloatBuffer.put(arr)
result
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy