- java.lang.Object
- 
- javafx.scene.image.PixelFormat<T>
 
- 
- Type Parameters:
- T- the type of buffer that stores the pixel data. Only- ByteBufferand- IntBufferare used.
 - Direct Known Subclasses:
- WritablePixelFormat
 
 public abstract class PixelFormat<T extends Buffer> extends Object APixelFormatobject defines the layout of data for a pixel of a given format.- Since:
- JavaFX 2.2
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classPixelFormat.TypeAn enum describing the in-array storage format of a single pixel managed by aPixelFormat.
 - 
Method SummaryModifier and Type Method Description static PixelFormat<ByteBuffer>createByteIndexedInstance(int[] colors)Creates aPixelFormatinstance describing a pixel layout with the pixels stored as single bytes representing an index into the specified lookup table of non-premultiplied color values in theINT_ARGBformat.static PixelFormat<ByteBuffer>createByteIndexedPremultipliedInstance(int[] colors)Creates aPixelFormatinstance describing a pixel layout with the pixels stored as single bytes representing an index into the specified lookup table of premultiplied color values in theINT_ARGB_PREformat.abstract intgetArgb(T buf, int x, int y, int scanlineStride)Reads pixel data from the buffer at the specified coordinates and converts it to a 32-bit integer representation of the color in theINT_ARGBformat.static WritablePixelFormat<ByteBuffer>getByteBgraInstance()Returns aWritablePixelFormatinstance describing a pixel layout with the pixels stored in adjacent bytes with the non-premultiplied components stored in order of increasing index: blue, green, red, alpha.static WritablePixelFormat<ByteBuffer>getByteBgraPreInstance()Returns aWritablePixelFormatinstance describing a pixel layout with the pixels stored in adjacent bytes with the premultiplied components stored in order of increasing index: blue, green, red, alpha.static PixelFormat<ByteBuffer>getByteRgbInstance()Returns aPixelFormatinstance describing a pixel layout with the pixels stored in adjacent bytes with the color components stored in order of increasing index: red, green, blue.static WritablePixelFormat<IntBuffer>getIntArgbInstance()Returns aWritablePixelFormatinstance describing a pixel layout with the pixels stored in 32-bit integers with the non-premultiplied components stored in order, from MSb to LSb: alpha, red, green, blue.static WritablePixelFormat<IntBuffer>getIntArgbPreInstance()Returns aWritablePixelFormatinstance describing a pixel layout with the pixels stored in 32-bit integers with the premultiplied components stored in order, from MSb to LSb: alpha, red, green, blue.PixelFormat.TypegetType()Returns the enum representing the storage format of the pixels managed by thisPixelFormatobject.abstract booleanisPremultiplied()Returns true iff the color components decoded (or encoded) by this format are pre-multiplied by the alpha component for more efficient blending calculations.abstract booleanisWritable()Returns true iff thisPixelFormatobject can convert color information into a pixel representation.
 
- 
- 
- 
Method Detail- 
getIntArgbInstancepublic static WritablePixelFormat<IntBuffer> getIntArgbInstance() Returns aWritablePixelFormatinstance describing a pixel layout with the pixels stored in 32-bit integers with the non-premultiplied components stored in order, from MSb to LSb: alpha, red, green, blue.Pixels in this format can be decoded using the following sample code: int pixel = array[rowstart + x]; int alpha = ((pixel >> 24) & 0xff); int red = ((pixel >> 16) & 0xff); int green = ((pixel >> 8) & 0xff); int blue = ((pixel >> ) & 0xff);- Returns:
- a WritabelPixelFormat<IntBuffer>describing the indicated pixel format
 
 - 
getIntArgbPreInstancepublic static WritablePixelFormat<IntBuffer> getIntArgbPreInstance() Returns aWritablePixelFormatinstance describing a pixel layout with the pixels stored in 32-bit integers with the premultiplied components stored in order, from MSb to LSb: alpha, red, green, blue.Pixels in this format can be decoded using the following sample code: int pixel = array[rowstart + x]; int alpha = ((pixel >> 24) & 0xff); int red = ((pixel >> 16) & 0xff); int green = ((pixel >> 8) & 0xff); int blue = ((pixel >> ) & 0xff);- Returns:
- a WritabelPixelFormat<IntBuffer>describing the indicated pixel format
 
 - 
getByteBgraInstancepublic static WritablePixelFormat<ByteBuffer> getByteBgraInstance() Returns aWritablePixelFormatinstance describing a pixel layout with the pixels stored in adjacent bytes with the non-premultiplied components stored in order of increasing index: blue, green, red, alpha.Pixels in this format can be decoded using the following sample code: int i = rowstart + x * 4; int blue = (array[i+0] & 0xff); int green = (array[i+1] & 0xff); int red = (array[i+2] & 0xff); int alpha = (array[i+3] & 0xff);- Returns:
- a WritablePixelFormat<ByteBuffer>describing the indicated pixel format
 
 - 
getByteBgraPreInstancepublic static WritablePixelFormat<ByteBuffer> getByteBgraPreInstance() Returns aWritablePixelFormatinstance describing a pixel layout with the pixels stored in adjacent bytes with the premultiplied components stored in order of increasing index: blue, green, red, alpha.Pixels in this format can be decoded using the following sample code: int i = rowstart + x * 4; int blue = (array[i+0] & 0xff); int green = (array[i+1] & 0xff); int red = (array[i+2] & 0xff); int alpha = (array[i+3] & 0xff);- Returns:
- a WritablePixelFormat<ByteBuffer>describing the indicated pixel format
 
 - 
getByteRgbInstancepublic static PixelFormat<ByteBuffer> getByteRgbInstance() Returns aPixelFormatinstance describing a pixel layout with the pixels stored in adjacent bytes with the color components stored in order of increasing index: red, green, blue.Pixels in this format can be decoded using the following sample code: int i = rowstart + x * 3; int red = (array[i+0] & 0xff); int green = (array[i+1] & 0xff); int blue = (array[i+2] & 0xff);- Returns:
- a PixelFormat<ByteBuffer>describing the indicated pixel format
 
 - 
createByteIndexedPremultipliedInstancepublic static PixelFormat<ByteBuffer> createByteIndexedPremultipliedInstance(int[] colors) Creates aPixelFormatinstance describing a pixel layout with the pixels stored as single bytes representing an index into the specified lookup table of premultiplied color values in theINT_ARGB_PREformat.Pixels in this format can be decoded using the following sample code: int pixel = array[rowstart + x] & 0xff; int argb = colors[pixel]; int alpha = ((argb >> 24) & 0xff); int red = ((argb >> 16) & 0xff); int green = ((argb >> 8) & 0xff); int blue = ((argb ) & 0xff);- Parameters:
- colors- an- int[]array of 32-bit color values in the- INT_ARGB_PREformat
- Returns:
- a PixelFormat<ByteBuffer>describing the indicated pixel format with the specified list of premultiplied colors
 
 - 
createByteIndexedInstancepublic static PixelFormat<ByteBuffer> createByteIndexedInstance(int[] colors) Creates aPixelFormatinstance describing a pixel layout with the pixels stored as single bytes representing an index into the specified lookup table of non-premultiplied color values in theINT_ARGBformat.Pixels in this format can be decoded using the following sample code: int pixel = array[rowstart + x] & 0xff; int argb = colors[pixel]; int alpha = ((argb >> 24) & 0xff); int red = ((argb >> 16) & 0xff); int green = ((argb >> 8) & 0xff); int blue = ((argb ) & 0xff);- Parameters:
- colors- an- int[]array of 32-bit color values in the- INT_ARGBformat
- Returns:
- a PixelFormat<ByteBuffer>describing the indicated pixel format with the specified list of non-premultiplied colors
 
 - 
getTypepublic PixelFormat.Type getType() Returns the enum representing the storage format of the pixels managed by thisPixelFormatobject.- Returns:
- the Typeenum of the pixels
 
 - 
isWritablepublic abstract boolean isWritable() Returns true iff thisPixelFormatobject can convert color information into a pixel representation.- Returns:
- true iff this PixelFormatcan convert colors to pixel data
 
 - 
isPremultipliedpublic abstract boolean isPremultiplied() Returns true iff the color components decoded (or encoded) by this format are pre-multiplied by the alpha component for more efficient blending calculations.- Returns:
- true iff the managed color components are premultiplied by alpha
 
 - 
getArgbpublic abstract int getArgb(T buf, int x, int y, int scanlineStride) Reads pixel data from the buffer at the specified coordinates and converts it to a 32-bit integer representation of the color in theINT_ARGBformat. The 32-bit integer will contain the 4 color components in separate 8-bit fields in ARGB order from the most significant byte to the least significant byte. The buffer should be positioned to the start of the pixel data such thatbuf.get(0)would return the pixel information for the pixel at coordinates(0, 0). ThescanlineStrideparameter defines the distance from the pixel data at the start of one row to the pixel data at the start of the immediately following row at the next higher Y coordinate. Usually,scanlineStrideis the same as the width of the image multiplied by the number of data elements per pixel (1 for the case of the integer and indexed formats, or 3 or 4 in the case of the byte formats), but some images may have further padding between rows for alignment or other purposes.The color components can be extracted from the returned integer using the following sample code: int alpha = ((retval >> 24) & 0xff); int red = ((retval >> 16) & 0xff); int green = ((retval >> 8) & 0xff); int blue = ((retval ) & 0xff);- Parameters:
- buf- the buffer of pixel data
- x- the X coordinate of the pixel to be read
- y- the Y coordinate of the pixel to be read
- scanlineStride- the number of buffer elements between the start of adjacent pixel rows in the buffer
- Returns:
- a 32-bit value with the color of the pixel in a format
         similar to the INT_ARGBpixel format
 
 
- 
 
-