|
|||||||||
摘要: 嵌套 | 字段 | 构造方法 | 方法 | 详细信息: 字段 | 构造方法 | 方法 |
java.awt.image
类 BandedSampleModel
java.lang.Object java.awt.image.SampleModel java.awt.image.ComponentSampleModel java.awt.image.BandedSampleModel
-
public final class BandedSampleModel
- extends ComponentSampleModel
此类表示按 band 交插方式存储的图像数据,像素的每个样本都占用 DataBuffer 的一个数据元素。此类是 ComponentSampleModel 的子类,但是对于访问 band 交插图像数据来说,它提供的实现比 ComponentSampleModel 提供的实现更有效。当处理存储在不同 DataBuffer 存储单元中每个 band 的样本数据的图像时,通常应该使用此类。由于提供了 Accessor 方法,因此可以直接对图像数据进行操作。像素间距 (pixel stride) 是同一 scanline 上同一 band 的两个样本之间的数据数组元素数。BandedSampleModel 的像素间距为 1。Scanline 间距是给定样本与下一 scanline 的同一列中对应样本之间的数据数组元素数。Band 偏移量表示从保存每个 band 的 DataBuffer 存储单元的第一个数据数组元素到 band 的第一个样本之间的数据数组元素数。这些 band 从 0 到 N-1 进行编号。存储单元索引表示数据缓冲区存储单元与图像数据 band 之间的对应关系。此类支持 TYPE_BYTE
、TYPE_USHORT
、TYPE_SHORT
、TYPE_INT
、TYPE_FLOAT
和 TYPE_DOUBLE
数据类型。
字段摘要 |
---|
从类 java.awt.image.ComponentSampleModel 继承的字段 |
---|
bandOffsets, bankIndices, numBands, numBanks, pixelStride, scanlineStride |
从类 java.awt.image.SampleModel 继承的字段 |
---|
dataType, height, width |
构造方法摘要 | |
---|---|
BandedSampleModel(int dataType, int w, int h, int numBands) 构造一个具有指定参数的 BandedSampleModel。 |
|
BandedSampleModel(int dataType, int w, int h, int scanlineStride, int[] bankIndices, int[] bandOffsets) 构造一个具有指定参数的 BandedSampleModel。 |
方法摘要 | |
---|---|
SampleModel |
createCompatibleSampleModel(int w, int h) 创建一个具有指定宽度和高度的新的 BandedSampleModel。 |
DataBuffer |
createDataBuffer() 创建一个与此 BandedSampleModel 对应的 DataBuffer,该 DataBuffer 的数据类型、存储单元数和大小都将与此 BandedSampleModel 一致。 |
SampleModel |
createSubsetSampleModel(int[] bands) 创建一个具有此 BandedSampleModel 的 band 子集的新 BandedSampleModel。 |
Object |
getDataElements(int x, int y, Object obj, DataBuffer data) 返回 TransferType 类型的基本数组中单个像素的数据。 |
int[] |
getPixel(int x, int y, int[] iArray, DataBuffer data) 返回 int 数组中指定像素的所有样本。 |
int[] |
getPixels(int x, int y, int w, int h, int[] iArray, DataBuffer data) 返回 int 数组中指定像素矩形的所有样本,每个数据数组元素对应一个样本。 |
int |
getSample(int x, int y, int b, DataBuffer data) 针对 (x,y) 处的像素,返回指定 band 中样本的 int 值。 |
double |
getSampleDouble(int x, int y, int b, DataBuffer data) 针对 (x,y) 处的像素,返回指定 band 中样本的 double 值。 |
float |
getSampleFloat(int x, int y, int b, DataBuffer data) 针对 (x,y) 处的像素,返回指定 band 中样本的 float 值。 |
int[] |
getSamples(int x, int y, int w, int h, int b, int[] iArray, DataBuffer data) 针对一个 int 数组中指定的像素矩形,返回指定 band 中的样本,每个数据数组元素对应一个样本。 |
int |
hashCode() 返回该对象的哈希码值。 |
void |
setDataElements(int x, int y, Object obj, DataBuffer data) 从 TransferType 类型的基本数组设置指定 DataBuffer 中单个像素的数据。 |
void |
setPixel(int x, int y, int[] iArray, DataBuffer data) 使用输入样本的 int 数组设置 DataBuffer 中的像素。 |
void |
setPixels(int x, int y, int w, int h, int[] iArray, DataBuffer data) 设置 int 数组中像素矩形的所有样本,该数组中包含每个数组元素的一个样本。 |
void |
setSample(int x, int y, int b, double s, DataBuffer data) 使用输入的 double 值,为 DataBuffer 中 (x,y) 处的像素设置指定 band 中的样本。 |
void |
setSample(int x, int y, int b, float s, DataBuffer data) 使用输入的 float 值,为 DataBuffer 中 (x,y) 处的像素设置指定 band 中的样本。 |
void |
setSample(int x, int y, int b, int s, DataBuffer data) 使用输入的 int 值,为 DataBuffer 中 (x,y) 处的像素设置指定 band 中的样本。 |
void |
setSamples(int x, int y, int w, int h, int b, int[] iArray, DataBuffer data) 为 int 数组中指定的像素矩形设置指定 band 中的样本,该数组中包含每个数据数组元素的一个样本。 |
从类 java.awt.image.ComponentSampleModel 继承的方法 |
---|
equals, getBandOffsets, getBankIndices, getNumDataElements, getOffset, getOffset, getPixelStride, getSampleSize, getSampleSize, getScanlineStride |
从类 java.awt.image.SampleModel 继承的方法 |
---|
getDataElements, getDataType, getHeight, getNumBands, getPixel, getPixel, getPixels, getPixels, getSamples, getSamples, getTransferType, getWidth, setDataElements, setPixel, setPixel, setPixels, setPixels, setSamples, setSamples |
从类 java.lang.Object 继承的方法 |
---|
clone, finalize, getClass, notify, notifyAll, toString, wait, wait, wait |
构造方法详细信息 |
---|
BandedSampleModel
public BandedSampleModel(int dataType, int w, int h, int numBands)
-
构造一个具有指定参数的 BandedSampleModel。像素间距将为一个数据元素。scanline 间距与宽度相同。每个 band 都存储在一个单独的存储单元中,所有 band 偏移量都为零。
- 参数:
-
dataType
- 存储样本的数据类型。 -
w
- 所描述的图像数据区域的宽度(以像素为单位)。 -
h
- 所描述的图像数据区域的高度(以像素为单位)。 -
numBands
- 图像数据的 band 数。 - 抛出:
-
IllegalArgumentException
- 如果dataType
不是受支持的数据类型之一
BandedSampleModel
public BandedSampleModel(int dataType, int w, int h, int scanlineStride, int[] bankIndices, int[] bandOffsets)
-
构造一个具有指定参数的 BandedSampleModel。可以从 bandOffsets bankIndices 数组的长度推断 band 数,它们必须相等。像素间距将为一个数据元素。
- 参数:
-
dataType
- 存储样本的数据类型。 -
w
- 所描述的图像数据区域的宽度(以像素为单位)。 -
h
- 所描述的图像数据区域的高度(以像素为单位)。 -
scanlineStride
- 图像数据的行间距。 -
bankIndices
- 每个 band 的存储单元索引。 -
bandOffsets
- 每个 band 的 band 偏移量。 - 抛出:
-
IllegalArgumentException
- 如果dataType
不是受支持的数据类型之一
方法详细信息 |
---|
createCompatibleSampleModel
public SampleModel createCompatibleSampleModel(int w, int h)
- 创建一个具有指定宽度和高度的新的 BandedSampleModel。新 BandedSampleModel 将具有与此 BandedSampleModel 相同的 band 数、存储数据类型和存储单元索引。band 偏移量将被压缩,使得 band 之间的偏移量为 w*pixelStride,并且所有 band 偏移量的最小值为零。
-
- 参数:
-
w
- 得到的BandedSampleModel
的宽度 -
h
- 得到的BandedSampleModel
的高度 - 返回:
-
具有指定宽度和高度的新
BandedSampleModel
。 - 抛出:
-
IllegalArgumentException
- 如果w
或h
等于Integer.MAX_VALUE
或Integer.MIN_VALUE
-
IllegalArgumentException
- 如果dataType
不是受支持的数据类型之一
createSubsetSampleModel
public SampleModel createSubsetSampleModel(int[] bands)
- 创建一个具有此 BandedSampleModel 的 band 子集的新 BandedSampleModel。新的 BandedSampleModel 可以与任何使用现有 BandedSampleModel 的 DataBuffer 一起使用。新的 BandedSampleModel/DataBuffer 组合将表示一个具有原 BandedSampleModel/DataBuffer 组合的 band 子集的图像。
-
- 参数:
-
bands
- 此ComponentSampleModel
的 band 的子集 - 返回:
-
已创建的具有此
ComponentSampleModel
的 band 子集的ComponentSampleModel
。 - 抛出:
-
RasterFormatException
- 如果 band 数大于此样本模型中的存储单元数。 -
IllegalArgumentException
- 如果dataType
不是受支持的数据类型之一
createDataBuffer
public DataBuffer createDataBuffer()
- 创建一个与此 BandedSampleModel 对应的 DataBuffer,该 DataBuffer 的数据类型、存储单元数和大小都将与此 BandedSampleModel 一致。
-
- 覆盖:
-
类
ComponentSampleModel
中的createDataBuffer
-
- 返回:
-
其数据类型、库的数量和大小与此
ComponentSampleModel
一致的DataBuffer
。 - 抛出:
-
IllegalArgumentException
- 如果dataType
不是受支持的类型之一。
getDataElements
public Object getDataElements(int x, int y, Object obj, DataBuffer data)
-
返回 TransferType 类型的基本数组中单个像素的数据。对于 BandedSampleModel,返回的数据与 data 相同,并为每个数组元素返回一个样本。通常,obj 应该作为 null 传入,这样 Object 将自动创建,并具有正确的基本数据类型。
以下代码说明了如何对一个像素进行从 DataBuffer
db1
(其存储布局由 BandedSampleModelbsm1
描述)到 DataBufferdb2
(其存储布局由 BandedSampleModelbsm2
描述)的数据传输。通常,该传输比使用 getPixel/setPixel 方法更高效。BandedSampleModel bsm1, bsm2; DataBufferInt db1, db2; bsm2.setDataElements(x, y, bsm1.getDataElements(x, y, null, db1), db2);
如果两个 SampleModels 具有相同的 band 数,相应 band 的每个样本具有相同的位数,且 TransferTypes 相同,则使用 getDataElements/setDataElements 在这两个 DataBuffer/SampleModel 对之间传输数据是合理的。如果 obj 不为 null,则它应该是一个基本的 TransferType 类型的数组。否则,抛出 ClassCastException。如果坐标不在边界内部,或者 obj 不为 null 且大小不足以容纳像素数据,则抛出 ArrayIndexOutOfBoundsException。
-
- 覆盖:
-
类
ComponentSampleModel
中的getDataElements
-
- 参数:
-
x, y
- 像素位置的坐标 -
obj
- 如果不为 null,则为一个用来返回像素数据的基本数组。 -
data
- 包含图像数据的 DataBuffer。 - 返回:
- 指定像素的数据。
- 另请参见:
-
setDataElements(int, int, Object, DataBuffer)
getPixel
public int[] getPixel(int x, int y, int[] iArray, DataBuffer data)
- 返回 int 数组中指定像素的所有样本。如果坐标不在边界内部,则可能抛出 ArrayIndexOutOfBoundsException。
-
- 覆盖:
-
类
ComponentSampleModel
中的getPixel
-
- 参数:
-
x, y
- 像素位置的坐标 -
iArray
- 如果不为 null,则返回此数组中的样本 -
data
- 包含图像数据的 DataBuffer - 返回:
- 指定像素的样本。
- 另请参见:
-
setPixel(int, int, int[], DataBuffer)
getPixels
public int[] getPixels(int x, int y, int w, int h, int[] iArray, DataBuffer data)
- 返回 int 数组中指定像素矩形的所有样本,每个数据数组元素对应一个样本。如果坐标不在边界内部,则可能抛出 ArrayIndexOutOfBoundsException。
-
- 覆盖:
-
类
ComponentSampleModel
中的getPixels
-
- 参数:
-
x, y
- 左上角像素位置的坐标 -
w
- 像素矩形的宽度 -
h
- 像素矩形的高度 -
iArray
- 如果不为 null,则返回此数组中的样本 -
data
- 包含图像数据的 DataBuffer - 返回:
- 指定区域中像素的样本。
- 另请参见:
-
setPixels(int, int, int, int, int[], DataBuffer)