public final class ImageData
extends java.lang.Object
Image
.
Note that the public fields x
, y
,
disposalMethod
and delayTime
are
typically only used when the image is in a set of images used
for animation.
Image
,
ImageLoader
Modifier and Type | Field and Description |
---|---|
int |
alpha
The global alpha value to be used for every pixel.
|
byte[] |
alphaData
The alpha data of the image.
|
int |
bytesPerLine
The number of bytes per scanline.
|
byte[] |
data
The pixel data of the image.
|
int |
delayTime
The time to delay before displaying the next image
in an animation (this field corresponds to the GIF89a
Delay Time value).
|
int |
depth
The color depth of the image, in bits per pixel.
|
int |
disposalMethod
A description of how to dispose of the current image
before displaying the next.
|
int |
height
The height of the image, in pixels.
|
byte[] |
maskData
An icon-specific field containing the data from the icon mask.
|
int |
maskPad
An icon-specific field containing the scanline pad of the mask.
|
PaletteData |
palette
The color table for the image.
|
int |
scanlinePad
The scanline padding.
|
int |
transparentPixel
The transparent pixel.
|
int |
type
The type of file from which the image was read.
|
int |
width
The width of the image, in pixels.
|
int |
x
The x coordinate of the top left corner of the image
within the logical screen (this field corresponds to
the GIF89a Image Left Position value).
|
int |
y
The y coordinate of the top left corner of the image
within the logical screen (this field corresponds to
the GIF89a Image Top Position value).
|
Constructor and Description |
---|
ImageData(java.io.InputStream stream)
Constructs an
ImageData loaded from the specified
input stream. |
ImageData(int width,
int height,
int depth,
PaletteData palette)
Constructs a new, empty ImageData with the given width, height,
depth and palette.
|
ImageData(int width,
int height,
int depth,
PaletteData palette,
int scanlinePad,
byte[] data)
Constructs a new, empty ImageData with the given width, height,
depth, palette, scanlinePad and data.
|
ImageData(java.lang.String filename)
Constructs an
ImageData loaded from a file with the
specified name. |
Modifier and Type | Method and Description |
---|---|
java.lang.Object |
clone()
Returns a new instance of the same class as the receiver,
whose slots have been filled in with copies of
the values in the slots of the receiver.
|
int |
getAlpha(int x,
int y)
Returns the alpha value at offset
x in
scanline y in the receiver's alpha data. |
void |
getAlphas(int x,
int y,
int getWidth,
byte[] alphas,
int startIndex)
Returns
getWidth alpha values starting at offset
x in scanline y in the receiver's alpha
data starting at startIndex . |
int |
getPixel(int x,
int y)
Returns the pixel value at offset
x in
scanline y in the receiver's data. |
void |
getPixels(int x,
int y,
int getWidth,
byte[] pixels,
int startIndex)
Returns
getWidth pixel values starting at offset
x in scanline y in the receiver's
data starting at startIndex . |
void |
getPixels(int x,
int y,
int getWidth,
int[] pixels,
int startIndex)
Returns
getWidth pixel values starting at offset
x in scanline y in the receiver's
data starting at startIndex . |
RGB[] |
getRGBs()
Returns an array of
RGB s which comprise the
indexed color table of the receiver, or null if the receiver
has a direct color model. |
ImageData |
getTransparencyMask()
Returns an
ImageData which specifies the
transparency mask information for the receiver. |
int |
getTransparencyType()
Returns the image transparency type, which will be one of
SWT.TRANSPARENCY_NONE , SWT.TRANSPARENCY_MASK ,
SWT.TRANSPARENCY_PIXEL or SWT.TRANSPARENCY_ALPHA . |
static ImageData |
internal_new(int width,
int height,
int depth,
PaletteData palette,
int scanlinePad,
byte[] data,
int maskPad,
byte[] maskData,
byte[] alphaData,
int alpha,
int transparentPixel,
int type,
int x,
int y,
int disposalMethod,
int delayTime)
Invokes internal SWT functionality to create a new instance of
this class.
|
ImageData |
scaledTo(int width,
int height)
Returns a copy of the receiver which has been stretched or
shrunk to the specified size.
|
void |
setAlpha(int x,
int y,
int alpha)
Sets the alpha value at offset
x in
scanline y in the receiver's alpha data. |
void |
setAlphas(int x,
int y,
int putWidth,
byte[] alphas,
int startIndex)
Sets the alpha values starting at offset
x in
scanline y in the receiver's alpha data to the
values from the array alphas starting at
startIndex . |
void |
setPixel(int x,
int y,
int pixelValue)
Sets the pixel value at offset
x in
scanline y in the receiver's data. |
void |
setPixels(int x,
int y,
int putWidth,
byte[] pixels,
int startIndex)
Sets the pixel values starting at offset
x in
scanline y in the receiver's data to the
values from the array pixels starting at
startIndex . |
void |
setPixels(int x,
int y,
int putWidth,
int[] pixels,
int startIndex)
Sets the pixel values starting at offset
x in
scanline y in the receiver's data to the
values from the array pixels starting at
startIndex . |
public int width
public int height
public int depth
Note that a depth of 8 or less does not necessarily mean that the image is palette indexed, or conversely that a depth greater than 8 means that the image is direct color. Check the associated PaletteData's isDirect field for such determinations.
public int scanlinePad
If one scanline of the image is not a multiple of this number, it will be padded with zeros until it is.
public int bytesPerLine
This is a multiple of the scanline padding.
public byte[] data
Note that for 16 bit depth images the pixel data is stored in least significant byte order; however, for 24bit and 32bit depth images the pixel data is stored in most significant byte order.
public PaletteData palette
public int transparentPixel
Pixels with this value are transparent.
The default is -1 which means 'no transparent pixel'.
public byte[] maskData
This is a 1 bit bitmap stored with the most significant bit first. The number of bytes per scanline is '((width + 7) / 8 + (maskPad - 1)) / maskPad * maskPad'.
The default is null which means 'no transparency mask'.
public int maskPad
If one scanline of the transparency mask is not a multiple of this number, it will be padded with zeros until it is.
public byte[] alphaData
Every pixel can have an alpha blending value that varies from 0, meaning fully transparent, to 255 meaning fully opaque. The number of bytes per scanline is 'width'.
public int alpha
If this value is set, the alphaData
field
is ignored and when the image is rendered each pixel
will be blended with the background an amount
proportional to this value.
The default is -1 which means 'no global alpha value'
public int type
IMAGE_BMP
IMAGE_BMP_RLE
IMAGE_GIF
IMAGE_ICO
IMAGE_JPEG
IMAGE_PNG
public int x
public int y
public int disposalMethod
DM_UNSPECIFIED
DM_FILL_NONE
DM_FILL_BACKGROUND
DM_FILL_PREVIOUS
public int delayTime
public ImageData(int width, int height, int depth, PaletteData palette)
width
- the width of the imageheight
- the height of the imagedepth
- the depth of the imagepalette
- the palette of the image (must not be null)java.lang.IllegalArgumentException
- public ImageData(int width, int height, int depth, PaletteData palette, int scanlinePad, byte[] data)
width
- the width of the imageheight
- the height of the imagedepth
- the depth of the imagepalette
- the palette of the imagescanlinePad
- the padding of each line, in bytesdata
- the data of the imagejava.lang.IllegalArgumentException
- public ImageData(java.io.InputStream stream)
ImageData
loaded from the specified
input stream. Throws an error if an error occurs while loading
the image, or if the image has an unsupported type. Application
code is still responsible for closing the input stream.
This constructor is provided for convenience when loading a single
image only. If the stream contains multiple images, only the first
one will be loaded. To load multiple images, use
ImageLoader.load()
.
This constructor may be used to load a resource as follows:
static ImageData loadImageData (Class clazz, String string) { InputStream stream = clazz.getResourceAsStream (string); if (stream == null) return null; ImageData imageData = null; try { imageData = new ImageData (stream); } catch (SWTException ex) { } finally { try { stream.close (); } catch (IOException ex) {} } return imageData; }
stream
- the input stream to load the image from (must not be null)java.lang.IllegalArgumentException
- SWTException
- ImageLoader.load(InputStream)
public ImageData(java.lang.String filename)
ImageData
loaded from a file with the
specified name. Throws an error if an error occurs loading the
image, or if the image has an unsupported type.
This constructor is provided for convenience when loading a single
image only. If the file contains multiple images, only the first
one will be loaded. To load multiple images, use
ImageLoader.load()
.
filename
- the name of the file to load the image from (must not be null)java.lang.IllegalArgumentException
- SWTException
- public static ImageData internal_new(int width, int height, int depth, PaletteData palette, int scanlinePad, byte[] data, int maskPad, byte[] maskData, byte[] alphaData, int alpha, int transparentPixel, int type, int x, int y, int disposalMethod, int delayTime)
IMPORTANT: This method is not part of the public
API for ImageData
. It is marked public only so that it
can be shared within the packages provided by SWT. It is subject
to change without notice, and should never be called from
application code.
This method is for internal use, and is not described further.
public java.lang.Object clone()
clone
in class java.lang.Object
public int getAlpha(int x, int y)
x
in
scanline y
in the receiver's alpha data.
The alpha value is between 0 (transparent) and
255 (opaque).x
- the x coordinate of the pixel to get the alpha value ofy
- the y coordinate of the pixel to get the alpha value ofjava.lang.IllegalArgumentException
- public void getAlphas(int x, int y, int getWidth, byte[] alphas, int startIndex)
getWidth
alpha values starting at offset
x
in scanline y
in the receiver's alpha
data starting at startIndex
. The alpha values
are unsigned, between (byte)0
(transparent) and
(byte)255
(opaque).x
- the x position of the pixel to begin getting alpha valuesy
- the y position of the pixel to begin getting alpha valuesgetWidth
- the width of the data to getalphas
- the buffer in which to put the alpha valuesstartIndex
- the offset into the image to begin getting alpha valuesjava.lang.IndexOutOfBoundsException
- if getWidth is too largejava.lang.IllegalArgumentException
- public int getPixel(int x, int y)
x
in
scanline y
in the receiver's data.x
- the x position of the pixel to gety
- the y position of the pixel to getjava.lang.IllegalArgumentException
- SWTException
- public void getPixels(int x, int y, int getWidth, byte[] pixels, int startIndex)
getWidth
pixel values starting at offset
x
in scanline y
in the receiver's
data starting at startIndex
.x
- the x position of the first pixel to gety
- the y position of the first pixel to getgetWidth
- the width of the data to getpixels
- the buffer in which to put the pixelsstartIndex
- the offset into the byte array to begin storing pixelsjava.lang.IndexOutOfBoundsException
- if getWidth is too largejava.lang.IllegalArgumentException
- SWTException
- public void getPixels(int x, int y, int getWidth, int[] pixels, int startIndex)
getWidth
pixel values starting at offset
x
in scanline y
in the receiver's
data starting at startIndex
.x
- the x position of the first pixel to gety
- the y position of the first pixel to getgetWidth
- the width of the data to getpixels
- the buffer in which to put the pixelsstartIndex
- the offset into the buffer to begin storing pixelsjava.lang.IndexOutOfBoundsException
- if getWidth is too largejava.lang.IllegalArgumentException
- SWTException
- public RGB[] getRGBs()
RGB
s which comprise the
indexed color table of the receiver, or null if the receiver
has a direct color model.PaletteData.getRGBs()
public ImageData getTransparencyMask()
ImageData
which specifies the
transparency mask information for the receiver. If the
receiver has no transparency or is not an icon, returns
an opaque mask.public int getTransparencyType()
SWT.TRANSPARENCY_NONE
, SWT.TRANSPARENCY_MASK
,
SWT.TRANSPARENCY_PIXEL
or SWT.TRANSPARENCY_ALPHA
.public ImageData scaledTo(int width, int height)
width
- the width of the new ImageDataheight
- the height of the new ImageDatapublic void setAlpha(int x, int y, int alpha)
x
in
scanline y
in the receiver's alpha data.
The alpha value must be between 0 (transparent)
and 255 (opaque).x
- the x coordinate of the alpha value to sety
- the y coordinate of the alpha value to setalpha
- the value to set the alpha tojava.lang.IllegalArgumentException
- public void setAlphas(int x, int y, int putWidth, byte[] alphas, int startIndex)
x
in
scanline y
in the receiver's alpha data to the
values from the array alphas
starting at
startIndex
. The alpha values must be between
(byte)0
(transparent) and (byte)255
(opaque)x
- the x coordinate of the pixel to being setting the alpha valuesy
- the y coordinate of the pixel to being setting the alpha valuesputWidth
- the width of the alpha values to setalphas
- the alpha values to setstartIndex
- the index at which to begin settingjava.lang.IndexOutOfBoundsException
- if putWidth is too largejava.lang.IllegalArgumentException
- public void setPixel(int x, int y, int pixelValue)
x
in
scanline y
in the receiver's data.x
- the x coordinate of the pixel to sety
- the y coordinate of the pixel to setpixelValue
- the value to set the pixel tojava.lang.IllegalArgumentException
- SWTException
- public void setPixels(int x, int y, int putWidth, byte[] pixels, int startIndex)
x
in
scanline y
in the receiver's data to the
values from the array pixels
starting at
startIndex
.x
- the x position of the pixel to sety
- the y position of the pixel to setputWidth
- the width of the pixels to setpixels
- the pixels to setstartIndex
- the index at which to begin settingjava.lang.IndexOutOfBoundsException
- if putWidth is too largejava.lang.IllegalArgumentException
- SWTException
- public void setPixels(int x, int y, int putWidth, int[] pixels, int startIndex)
x
in
scanline y
in the receiver's data to the
values from the array pixels
starting at
startIndex
.x
- the x position of the pixel to sety
- the y position of the pixel to setputWidth
- the width of the pixels to setpixels
- the pixels to setstartIndex
- the index at which to begin settingjava.lang.IndexOutOfBoundsException
- if putWidth is too largejava.lang.IllegalArgumentException
- SWTException
-
Copyright (c) EclipseSource and others 2002, 2014.
All rights reserved. This program and the accompanying materials
are made available under the terms of the
Eclipse Public License v1.0