返回介绍

java.awt.image 类 PixelGrabber

发布于 2019-10-04 09:50:35 字数 18601 浏览 1120 评论 0 收藏 0

java.lang.Object
  └java.awt.image.PixelGrabber
所有已实现的接口:
ImageConsumer

public class PixelGrabber
extends Object
 
implements ImageConsumer
 

PixelGrabber 类实现可以附加在 Image 或 ImageProducer 对象上以获得该图像像素子集的 ImageConsumer。下面是一个示例:

 public void handlesinglepixel(int x, int y, int pixel) {
        int alpha = (pixel >> 24) & 0xff;
        int red   = (pixel >> 16) & 0xff;
        int green = (pixel >>  8) & 0xff;
        int blue  = (pixel      ) & 0xff;
        // Deal with the pixel as necessary...
 }

 public void handlepixels(Image img, int x, int y, int w, int h) {
        int[] pixels = new int[w * h];
        PixelGrabber pg = new PixelGrabber(img, x, y, w, h, pixels, 0, w);
        try {
            pg.grabPixels();
        } catch (InterruptedException e) {
            System.err.println("interrupted waiting for pixels!");
            return;
        }
        if ((pg.getStatus() & ImageObserver.ABORT) != 0) {
            System.err.println("image fetch aborted or errored");
            return;
        }
        for (int j = 0; j < h; j++) {
            for (int i = 0; i < w; i++) {
                handlesinglepixel(x+i, y+j, pixels[j * w + i]);
            }
        }
 }
另请参见:
ColorModel.getRGBdefault()

字段摘要
从接口 java.awt.image.ImageConsumer 继承的字段
COMPLETESCANLINES, IMAGEABORTED, IMAGEERROR, RANDOMPIXELORDER, SINGLEFRAME, SINGLEFRAMEDONE, SINGLEPASS, STATICIMAGEDONE, TOPDOWNLEFTRIGHT
构造方法摘要
PixelGrabber(Imageimg, intx, inty, intw, inth, booleanforceRGB)

创建一个 PixelGrabber 对象,以便从指定的图像中抓取像素矩形部分 (x, y, w, h)。

PixelGrabber(Imageimg, intx, inty, intw, inth, int[]pix, intoff, intscansize)

创建一个 PixelGrabber 对象,以便从指定的图像中将像素矩形部分 (x, y, w, h) 抓取到给定的数组中。

PixelGrabber(ImageProducerip, intx, inty, intw, inth, int[]pix, intoff, intscansize)

创建一个 PixelGrabber 对象,以便从指定 ImageProducer 所生成的图像中将像素矩形部分 (x, y, w, h) 抓取到给定的数组中。

方法摘要
voidabortGrabbing()

请求 PixelGrabber 中止图像的获取。

ColorModelgetColorModel()

获得该数组中所存储像素的 ColorModel。

intgetHeight()

获得(调整图像高度后的)像素缓冲区的高度。

ObjectgetPixels()

获得像素缓冲区。

intgetStatus()

返回像素的状态。

intgetWidth()

获得(调整图像宽度后的)像素缓冲区的宽度。

booleangrabPixels()

请求 Image 或 ImageProducer 开始传递像素,并等待传递完相关矩形中的所有像素。

booleangrabPixels(longms)

请求 Image 或 ImageProducer 开始传递像素,并等待传递完相关矩形中的所有像素,或者等待到超时期已过。

voidimageComplete(intstatus)

为了检索像素,imageComplete 方法是此类必须实现的 ImageConsumer API 的一部分。

voidsetColorModel(ColorModelmodel)

为了检索像素,setColorModel 方法是此类必须实现的 ImageConsumer API 的一部分。

voidsetDimensions(intwidth, intheight)

为了检索像素,setDimensions 方法是此类必须实现的 ImageConsumer API 的一部分。

voidsetHints(inthints)

为了检索像素,setHints 方法是此类必须实现的 ImageConsumer API 的一部分。

voidsetPixels(intsrcX, intsrcY, intsrcW, intsrcH, ColorModelmodel, byte[]pixels, intsrcOff, intsrcScan)

为了检索像素,setPixels 方法是此类必须实现的 ImageConsumer API 的一部分。

voidsetPixels(intsrcX, intsrcY, intsrcW, intsrcH, ColorModelmodel, int[]pixels, intsrcOff, intsrcScan)

为了检索像素,setPixels 方法是此类必须实现的 ImageConsumer API 的一部分。

voidsetProperties(Hashtable<?,?>props)

为了检索像素,setProperties 方法是此类必须实现的 ImageConsumer API 的一部分。

voidstartGrabbing()

请求 PixelGrabber 开始获取像素。

intstatus()

返回像素的状态返回表示可用像素信息的 ImageObserver 标志。

从类 java.lang.Object 继承的方法
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait

构造方法详细信息

PixelGrabber

public PixelGrabber(Imageimg,
                    intx,
                    inty,
                    intw,
                    inth,
                    int[]pix,
                    intoff,
                    intscansize)
创建一个 PixelGrabber 对象,以便从指定的图像中将像素矩形部分 (x, y, w, h) 抓取到给定的数组中。以默认的 RGB ColorModel 形式将像素存储到数组中。像素 (i, j)(其中 (i, j) 处于矩形 (x, y, w, h) 内)的 RGB 数据存储在数组中的 pix[(j - y) * scansize + (i - x) + off] 位置处。
参数:
img - 从中检索像素的图像
x - 从图像中进行检索的像素矩形左上角 x 坐标,该矩形是相对于默认(未缩放)图像大小的
y - 从图像中进行检索的像素矩形左上角 y 坐标
w - 要检索的像素矩形的宽度
h - 要检索的像素矩形的高度
pix - 用于保存从图像中检索的 RGB 像素的整数数组
off - 数组中存储首个像素的偏移量
scansize - 数组中一行像素到下一行像素之间的距离
另请参见:
ColorModel.getRGBdefault()

PixelGrabber

public PixelGrabber(ImageProducerip,
                    intx,
                    inty,
                    intw,
                    inth,
                    int[]pix,
                    intoff,
                    intscansize)
创建一个 PixelGrabber 对象,以便从指定 ImageProducer 所生成的图像中将像素矩形部分 (x, y, w, h) 抓取到给定的数组中。以默认的 RGB ColorModel 形式将像素存储到数组中。像素 (i, j)(其中 (i, j) 处于矩形 (x, y, w, h) 内)的 RGB 数据存储在数组中的 pix[(j - y) * scansize + (i - x) + off] 位置处。
参数:
ip - 生成图像的 ImageProducer ,从该图像中检索像素
x - 从图像中进行检索的像素矩形左上角 x 坐标,该矩形是相对于默认(未缩放)图像大小的
y - 从图像中进行检索的像素矩形左上角 y 坐标
w - 要检索的像素矩形的宽度
h - 要检索的像素矩形的高度
pix - 用于保存从图像中检索的 RGB 像素的整数数组
off - 数组中存储首个像素的偏移量
scansize - 数组中一行像素到下一行像素之间的距离
另请参见:
ColorModel.getRGBdefault()

PixelGrabber

public PixelGrabber(Imageimg,
                    intx,
                    inty,
                    intw,
                    inth,
                    booleanforceRGB)
创建一个 PixelGrabber 对象,以便从指定的图像中抓取像素矩形部分 (x, y, w, h)。如果每次调用 setPixels 都使用相同的 ColorModel,则将像素累积存储到原来的 ColorModel 中,否则将像素累积存储到默认 RGB ColorModel 中。如果 forceRGB 参数为 true,则总是将像素累积存储到默认 RGB ColorModel 中。无论是哪种情况,PixelGrabber 都会分配一个缓冲区来保存这些像素。如果 (w < 0) 或 (h < 0),则默认它们为传递信息时保存的源数据的宽度和高度。
参数:
img - 要从中检索图像数据的图像
x - 从图像中进行检索的像素矩形左上角 x 坐标,该矩形是相对于默认(未缩放)图像大小
y - 从图像中进行检索的像素矩形左上角 y 坐标
w - 要检索的像素矩形的宽度
h - 要检索的像素矩形的高度
forceRGB - 如果总是应该将像素转换为默认 RGB ColorModel,则为 true

方法详细信息

startGrabbing

public void startGrabbing()
请求 PixelGrabber 开始获取像素。

abortGrabbing

public void abortGrabbing()
请求 PixelGrabber 中止图像的获取。

grabPixels

public boolean grabPixels()
                   throws InterruptedException
请求 Image 或 ImageProducer 开始传递像素,并等待传递完相关矩形中的所有像素。
返回:
如果成功抓取了像素,则返回 true;在中止、有错误或超时的情况下返回 false
抛出:
InterruptedException - 另一个线程中断了此线程。

grabPixels

public boolean grabPixels(longms)
                   throws InterruptedException
请求 Image 或 ImageProducer 开始传递像素,并等待传递完相关矩形中的所有像素,或者等待到超时期已过。根据 ms 值的不同,此方法采取下列行为:
  • 如果 ms == 0,则等待到传递完所有像素
  • 如果 ms > 0,则传递所有像素,直到超时为止。
  • 如果 ms < 0,则在抓取所有像素后返回 true ;否则返回 false 并且不等待。
参数:
ms - 在超时前等待获取图像像素的毫秒数
返回:
如果成功抓取了像素,则返回 true;在中止、有错误或超时的情况下返回 false
抛出:
InterruptedException - 另一个线程中断了此线程。

getStatus

public int getStatus()
返回像素的状态。返回表示可用像素信息的 ImageObserver 标志。
返回:
所有相关 ImageObserver 标志按位进行 OR 运算后的结果
另请参见:
ImageObserver

getWidth

public int getWidth()
获得(调整图像宽度后的)像素缓冲区的宽度。如果未指定要抓取的像素矩形的宽度,则仅在为图像传递尺寸后此信息才有效。
返回:
像素缓冲区的最终宽度,或者如果宽度未知,则为 -1
另请参见:
getStatus()

getHeight

public int getHeight()
获得(调整图像高度后的)像素缓冲区的高度。如果未指定要抓取的像素矩形的高度,则仅在为图像传递尺寸后此信息才有效。
返回:
像素缓冲区的最终高度,或者如果高度未知,则为 -1
另请参见:
getStatus()

getPixels

public Object getPixels()
获得像素缓冲区。如果没有使用保存像素的显式像素缓冲区来构造 PixelGrabber,则在知道图像数据的大小和格式前,此方法将返回 null。因为当源图像使用多个 ColorModel 来传递数据时,PixelGrabber 随时都可能回退到使用默认 RGB ColorModel 存储数据,所以在图像抓取完成前,此方法返回的数组对象可能随时间的推移而变化。
返回:
byte 数组或 int 数组
另请参见:
getStatus() , setPixels(int, int, int, int, ColorModel, byte[], int, int) , setPixels(int, int, int, int, ColorModel, int[], int, int)

getColorModel

public ColorModel getColorModel()
获得该数组中所存储像素的 ColorModel。如果使用显式像素缓冲区构造此 PixelGrabber,则此方法将始终返回默认的 RGB ColorModel,否则在知道 ImageProducer 使用的 ColorModel 前,此方法可能返回 null。因为当源图像使用多个 ColorModel 来传递数据时,PixelGrabber 随时都可能回退到使用默认 RGB ColorModel 存储数据,所以在图像抓取完成前,此方法返回的 ColorModel 对象可能随时间的推移而变化,并且可能无法反映 ImageProducer 传递像素所使用的任意 ColorModel 对象。
返回:
存储像素所用的 ColorModel 对象
另请参见:
getStatus() , ColorModel.getRGBdefault() , setColorModel(ColorModel)

setDimensions

public void setDimensions(intwidth,
                          intheight)
为了检索像素,setDimensions 方法是此类必须实现的 ImageConsumer API 的一部分。

注:此方法应该由 Image(要从中抓取像素)的 ImageProducer 来调用。使用此类检索图像像素的开发人员应该避免直接调用此方法,因为该调用操作可能对检索请求的像素产生问题。

指定者:
接口 ImageConsumer 中的 setDimensions
参数:
width - 该尺寸的宽度
height - 该尺寸的高度

setHints

public void setHints(inthints)
为了检索像素,setHints 方法是此类必须实现的 ImageConsumer API 的一部分。

注:此方法应该由 Image(要从中抓取像素)的 ImageProducer 来调用。使用此类检索图像像素的开发人员应该避免直接调用此方法,因为该调用操作可能对检索请求的像素产生问题。

指定者:
接口 ImageConsumer 中的 setHints
参数:
hints - 用于处理像素的提示集

setProperties

public void setProperties(Hashtable<?,?>props)
为了检索像素,setProperties 方法是此类必须实现的 ImageConsumer API 的一部分。

注:此方法应该由 Image(要从中抓取像素)的 ImageProducer 来调用。使用此类检索图像像素的开发人员应该避免直接调用此方法,因为该调用操作可能对检索请求的像素产生问题。

指定者:
接口 ImageConsumer 中的 setProperties
参数:
props - 属性列表

setColorModel

public void setColorModel(ColorModelmodel)
为了检索像素,setColorModel 方法是此类必须实现的 ImageConsumer API 的一部分。

注:此方法应该由 Image(要从中抓取像素)的 ImageProducer 来调用。使用此类检索图像像素的开发人员应该避免直接调用此方法,因为该调用操作可能对检索请求的像素产生问题。

指定者:
接口 ImageConsumer 中的 setColorModel
参数:
model - 指定的 ColorModel
另请参见:
getColorModel()

setPixels

public void setPixels(intsrcX,
                      intsrcY,
                      intsrcW,
                      intsrcH,
                      ColorModelmodel,
                      byte[]pixels,
                      intsrcOff,
                      intsrcScan)
为了检索像素,setPixels 方法是此类必须实现的 ImageConsumer API 的一部分。

注:此方法应该由 Image(要从中抓取像素)的 ImageProducer 来调用。使用此类检索图像像素的开发人员应该避免直接调用此方法,因为该调用操作可能对检索请求的像素产生问题。

指定者:
接口 ImageConsumer 中的 setPixels
参数:
srcX,srcY - 要设置像素区域左上角的坐标
srcW - 像素区域的宽度
srcH - 像素区域的高度
model - 指定的 ColorModel
pixels - 像素数组
srcOff - pixels 数组中的偏移量
srcScan - pixels 数组中一行像素到下一行的距离
另请参见:
getPixels()

setPixels

public void setPixels(intsrcX,
                      intsrcY,
                      intsrcW,
                      intsrcH,
                      ColorModelmodel,
                      int[]pixels,
                      intsrcOff,
                      intsrcScan)
为了检索像素,setPixels 方法是此类必须实现的 ImageConsumer API 的一部分。

注:此方法应该由 Image(要从中抓取像素)的 ImageProducer 来调用。使用此类检索图像像素的开发人员应该避免直接调用此方法,因为该调用操作可能对检索请求的像素产生问题。

指定者:
接口 ImageConsumer 中的 setPixels
参数:
srcX, srcY - 要设置像素区域左上角的坐标
srcW - 像素区域的宽度
srcH - 像素区域的高度
model - 指定的 ColorModel
pixels - 像素数组
srcOff - pixels 数组中的偏移量
srcScan - pixels 数组中一行像素到下一行的距离
另请参见:
getPixels()

imageComplete

public void imageComplete(intstatus)
为了检索像素,imageComplete 方法是此类必须实现的 ImageConsumer API 的一部分。

注:此方法应该由 Image(要从中抓取像素)的 ImageProducer 来调用。使用此类检索图像像素的开发人员应该避免直接调用此方法,因为该调用操作可能对检索请求的像素产生问题。

指定者:
接口 ImageConsumer 中的 imageComplete
参数:
status - 正在加载的图像的状态
另请参见:
ImageProducer.removeConsumer(java.awt.image.ImageConsumer)

status

public int status()
返回像素的状态返回表示可用像素信息的 ImageObserver 标志。此方法和 getStatus 具有相同的实现,但是优先使用 getStatus 方法,因为它遵循了检索信息方法的命名约定,即 "getXXX" 的形式。
返回:
所有相关 ImageObserver 标志按位进行 OR 运算后的结果
另请参见:
ImageObserver , getStatus()

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文