- java.lang.Object
- 
- java.awt.image.ColorConvertOp
 
- 
- All Implemented Interfaces:
- BufferedImageOp,- RasterOp
 
 public class ColorConvertOp extends Object implements BufferedImageOp, RasterOp This class performs a pixel-by-pixel color conversion of the data in the source image. The resulting color values are scaled to the precision of the destination image. Color conversion can be specified via an array of ColorSpace objects or an array of ICC_Profile objects.If the source is a BufferedImage with premultiplied alpha, the color components are divided by the alpha component before color conversion. If the destination is a BufferedImage with premultiplied alpha, the color components are multiplied by the alpha component after conversion. Rasters are treated as having no alpha channel, i.e. all bands are color bands. If a RenderingHints object is specified in the constructor, the color rendering hint and the dithering hint may be used to control color conversion. Note that Source and Destination may be the same object. 
- 
- 
Constructor SummaryConstructors Constructor Description ColorConvertOp(ColorSpace srcCspace, ColorSpace dstCspace, RenderingHints hints)Constructs a new ColorConvertOp from two ColorSpace objects.ColorConvertOp(ColorSpace cspace, RenderingHints hints)Constructs a new ColorConvertOp from a ColorSpace object.ColorConvertOp(ICC_Profile[] profiles, RenderingHints hints)Constructs a new ColorConvertOp from an array of ICC_Profiles.ColorConvertOp(RenderingHints hints)Constructs a new ColorConvertOp which will convert from a source color space to a destination color space.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description BufferedImagecreateCompatibleDestImage(BufferedImage src, ColorModel destCM)Creates a zeroed destination image with the correct size and number of bands, given this source.WritableRastercreateCompatibleDestRaster(Raster src)Creates a zeroed destination Raster with the correct size and number of bands, given this source.BufferedImagefilter(BufferedImage src, BufferedImage dest)ColorConverts the source BufferedImage.WritableRasterfilter(Raster src, WritableRaster dest)ColorConverts the image data in the source Raster.Rectangle2DgetBounds2D(BufferedImage src)Returns the bounding box of the destination, given this source.Rectangle2DgetBounds2D(Raster src)Returns the bounding box of the destination, given this source.ICC_Profile[]getICC_Profiles()Returns the array of ICC_Profiles used to construct this ColorConvertOp.Point2DgetPoint2D(Point2D srcPt, Point2D dstPt)Returns the location of the destination point given a point in the source.RenderingHintsgetRenderingHints()Returns the rendering hints used by this op.
 
- 
- 
- 
Constructor Detail- 
ColorConvertOppublic ColorConvertOp(RenderingHints hints) Constructs a new ColorConvertOp which will convert from a source color space to a destination color space. The RenderingHints argument may be null. This Op can be used only with BufferedImages, and will convert directly from the ColorSpace of the source image to that of the destination. The destination argument of the filter method cannot be specified as null.- Parameters:
- hints- the- RenderingHintsobject used to control the color conversion, or- null
 
 - 
ColorConvertOppublic ColorConvertOp(ColorSpace cspace, RenderingHints hints) Constructs a new ColorConvertOp from a ColorSpace object. The RenderingHints argument may be null. This Op can be used only with BufferedImages, and is primarily useful when thefiltermethod is invoked with a destination argument of null. In that case, the ColorSpace defines the destination color space for the destination created by the filter method. Otherwise, the ColorSpace defines an intermediate space to which the source is converted before being converted to the destination space.- Parameters:
- cspace- defines the destination- ColorSpaceor an intermediate- ColorSpace
- hints- the- RenderingHintsobject used to control the color conversion, or- null
- Throws:
- NullPointerException- if cspace is null
 
 - 
ColorConvertOppublic ColorConvertOp(ColorSpace srcCspace, ColorSpace dstCspace, RenderingHints hints) Constructs a new ColorConvertOp from two ColorSpace objects. The RenderingHints argument may be null. This Op is primarily useful for calling the filter method on Rasters, in which case the two ColorSpaces define the operation to be performed on the Rasters. In that case, the number of bands in the source Raster must match the number of components in srcCspace, and the number of bands in the destination Raster must match the number of components in dstCspace. For BufferedImages, the two ColorSpaces define intermediate spaces through which the source is converted before being converted to the destination space.- Parameters:
- srcCspace- the source- ColorSpace
- dstCspace- the destination- ColorSpace
- hints- the- RenderingHintsobject used to control the color conversion, or- null
- Throws:
- NullPointerException- if either srcCspace or dstCspace is null
 
 - 
ColorConvertOppublic ColorConvertOp(ICC_Profile[] profiles, RenderingHints hints) Constructs a new ColorConvertOp from an array of ICC_Profiles. The RenderingHints argument may be null. The sequence of profiles may include profiles that represent color spaces, profiles that represent effects, etc. If the whole sequence does not represent a well-defined color conversion, an exception is thrown.For BufferedImages, if the ColorSpace of the source BufferedImage does not match the requirements of the first profile in the array, the first conversion is to an appropriate ColorSpace. If the requirements of the last profile in the array are not met by the ColorSpace of the destination BufferedImage, the last conversion is to the destination's ColorSpace. For Rasters, the number of bands in the source Raster must match the requirements of the first profile in the array, and the number of bands in the destination Raster must match the requirements of the last profile in the array. The array must have at least two elements or calling the filter method for Rasters will throw an IllegalArgumentException. - Parameters:
- profiles- the array of- ICC_Profileobjects
- hints- the- RenderingHintsobject used to control the color conversion, or- null
- Throws:
- IllegalArgumentException- when the profile sequence does not specify a well-defined color conversion
- NullPointerException- if profiles is null
 
 
- 
 - 
Method Detail- 
getICC_Profilespublic final ICC_Profile[] getICC_Profiles() Returns the array of ICC_Profiles used to construct this ColorConvertOp. Returns null if the ColorConvertOp was not constructed from such an array.- Returns:
- the array of ICC_Profileobjects of thisColorConvertOp, ornullif thisColorConvertOpwas not constructed with an array ofICC_Profileobjects.
 
 - 
filterpublic final BufferedImage filter(BufferedImage src, BufferedImage dest) ColorConverts the source BufferedImage. If the destination image is null, a BufferedImage will be created with an appropriate ColorModel.- Specified by:
- filterin interface- BufferedImageOp
- Parameters:
- src- the source- BufferedImageto be converted
- dest- the destination- BufferedImage, or- null
- Returns:
- destcolor converted from- srcor a new, converted- BufferedImageif- destis- null
- Throws:
- IllegalArgumentException- if dest is null and this op was constructed using the constructor which takes only a RenderingHints argument, since the operation is ill defined.
 
 - 
filterpublic final WritableRaster filter(Raster src, WritableRaster dest) ColorConverts the image data in the source Raster. If the destination Raster is null, a new Raster will be created. The number of bands in the source and destination Rasters must meet the requirements explained above. The constructor used to create this ColorConvertOp must have provided enough information to define both source and destination color spaces. See above. Otherwise, an exception is thrown.- Specified by:
- filterin interface- RasterOp
- Parameters:
- src- the source- Rasterto be converted
- dest- the destination- WritableRaster, or- null
- Returns:
- destcolor converted from- srcor a new, converted- WritableRasterif- destis- null
- Throws:
- IllegalArgumentException- if the number of source or destination bands is incorrect, the source or destination color spaces are undefined, or this op was constructed with one of the constructors that applies only to operations on BufferedImages.
 
 - 
getBounds2Dpublic final Rectangle2D getBounds2D(BufferedImage src) Returns the bounding box of the destination, given this source. Note that this will be the same as the bounding box of the source.- Specified by:
- getBounds2Din interface- BufferedImageOp
- Parameters:
- src- the source- BufferedImage
- Returns:
- a Rectangle2Dthat is the bounding box of the destination, given the specifiedsrc
 
 - 
getBounds2Dpublic final Rectangle2D getBounds2D(Raster src) Returns the bounding box of the destination, given this source. Note that this will be the same as the bounding box of the source.- Specified by:
- getBounds2Din interface- RasterOp
- Parameters:
- src- the source- Raster
- Returns:
- a Rectangle2Dthat is the bounding box of the destination, given the specifiedsrc
 
 - 
createCompatibleDestImagepublic BufferedImage createCompatibleDestImage(BufferedImage src, ColorModel destCM) Creates a zeroed destination image with the correct size and number of bands, given this source.- Specified by:
- createCompatibleDestImagein interface- BufferedImageOp
- Parameters:
- src- Source image for the filter operation.
- destCM- ColorModel of the destination. If null, an appropriate ColorModel will be used.
- Returns:
- a BufferedImagewith the correct size and number of bands from the specifiedsrc.
- Throws:
- IllegalArgumentException- if- destCMis- nulland this- ColorConvertOpwas created without any- ICC_Profileor- ColorSpacedefined for the destination
 
 - 
createCompatibleDestRasterpublic WritableRaster createCompatibleDestRaster(Raster src) Creates a zeroed destination Raster with the correct size and number of bands, given this source.- Specified by:
- createCompatibleDestRasterin interface- RasterOp
- Parameters:
- src- the specified- Raster
- Returns:
- a WritableRasterwith the correct size and number of bands from the specifiedsrc
- Throws:
- IllegalArgumentException- if this- ColorConvertOpwas created without sufficient information to define the- dstand- srccolor spaces
 
 - 
getPoint2Dpublic final Point2D getPoint2D(Point2D srcPt, Point2D dstPt) Returns the location of the destination point given a point in the source. IfdstPtis non-null, it will be used to hold the return value. Note that for this class, the destination point will be the same as the source point.- Specified by:
- getPoint2Din interface- BufferedImageOp
- Specified by:
- getPoint2Din interface- RasterOp
- Parameters:
- srcPt- the specified source- Point2D
- dstPt- the destination- Point2D
- Returns:
- dstPtafter setting its location to be the same as- srcPt
 
 - 
getRenderingHintspublic final RenderingHints getRenderingHints() Returns the rendering hints used by this op.- Specified by:
- getRenderingHintsin interface- BufferedImageOp
- Specified by:
- getRenderingHintsin interface- RasterOp
- Returns:
- the RenderingHintsobject of thisColorConvertOp
 
 
- 
 
-