public final class PaletteData
extends java.lang.Object
Depending on the depth of the image, the PaletteData can take one of two forms, indicated by the isDirect field:
false, this palette is an indexed
 palette which maps pixel values to RGBs. The actual RGB values
 may be retrieved by using the getRGBs() method.
 true, this palette is a direct color
 palette. Instead of containing RGB values, it contains red,
 green and blue mask and shift information which indicates how
 the color components may be extracted from a given pixel.
 This means that the RGB value is actually encoded in the pixel value.
 In this case, the shift data is the number of bits required to shift the RGB value to the left in order to align the high bit of the corresponding mask with the high bit of the first byte. This number may be negative, so care must be taken when shifting. For example, with a red mask of 0xFF0000, the red shift would be -16. With a red mask of 0x1F, the red shift would be 3.
| Modifier and Type | Field and Description | 
|---|---|
| int | blueMaskthe blue mask for a direct palette | 
| int | blueShiftthe blue shift for a direct palette | 
| RGB[] | colorsthe RGB values for an indexed palette, where the
 indices of the array correspond to pixel values | 
| int | greenMaskthe green mask for a direct palette | 
| int | greenShiftthe green shift for a direct palette | 
| boolean | isDirecttrue if the receiver is a direct palette, 
 and false otherwise | 
| int | redMaskthe red mask for a direct palette | 
| int | redShiftthe red shift for a direct palette | 
| Constructor and Description | 
|---|
| PaletteData(int redMask,
           int greenMask,
           int blueMask)Constructs a new direct palette given the red, green and blue masks. | 
| PaletteData(RGB... colors)Constructs a new indexed palette given an array of RGB values. | 
| Modifier and Type | Method and Description | 
|---|---|
| int | getPixel(RGB rgb)Returns the pixel value corresponding to the given  RGB. | 
| RGB | getRGB(int pixel)Returns an  RGBcorresponding to the given pixel value. | 
| RGB[] | getRGBs()Returns all the RGB values in the receiver if it is an
 indexed palette, or null if it is a direct palette. | 
public boolean isDirect
public RGB[] colors
public int redMask
public int greenMask
public int blueMask
public int redShift
public int greenShift
public int blueShift
public PaletteData(RGB... colors)
colors - the array of RGBs for the palettejava.lang.IllegalArgumentException - public PaletteData(int redMask,
           int greenMask,
           int blueMask)
redMask - the red maskgreenMask - the green maskblueMask - the blue maskpublic int getPixel(RGB rgb)
RGB.rgb - the RGB to get the pixel value forjava.lang.IllegalArgumentException - public RGB getRGB(int pixel)
RGB corresponding to the given pixel value.pixel - the pixel to get the RGB value forjava.lang.IllegalArgumentException - public RGB[] getRGBs()
RGBs for the receiver or null
         
          Copyright (c) EclipseSource and others 2002, 2017.
          All rights reserved. This program and the accompanying materials
          are made available under the terms of the
          Eclipse Public License v1.0