Class AbstractImageFilter
- java.lang.Object
- 
- ca.cgjennings.graphics.filters.AbstractImageFilter
 
- 
- All Implemented Interfaces:
- java.awt.image.BufferedImageOp
 - Direct Known Subclasses:
- AbstractImagewiseFilter,- AbstractPixelwiseFilter,- AbstractRowwiseFilter,- BlurFilter,- GlowFilter,- MarginFilter,- PixelArtUpscalingFilter,- StrokeFilter,- TrimFilter,- TurnAndFlipFilter
 
 public abstract class AbstractImageFilter extends java.lang.Object implements java.awt.image.BufferedImageOpAn abstract base class for filtering images. WhileBufferedImageOps are generally designed to operate on images that use any storage format or colour model,AbstractImageFilteris optimized to work with 32-bit ARGB image data (BufferedImage.TYPE_INT_ARGB). Images stored in other formats will typically be converted to and from ARGB data as necessary. This greatly simplifies the task of writing an image filter, though at the cost of conversion (when required).This base class provides default implementations for many methods of BufferedImageOp. These default implementations are suitable for any operation that does not change the shape or size of the image. Most concrete filters will not subclass this base class directly, but will instead subclass one ofAbstractPixelwiseFilter,AbstractRowwiseFilter, orAbstractImagewiseFilter.Performance note: As a side effect of automatic conversion, image types other than TYPE_INT_ARGBandTYPE_INT_RGBwill become unmanaged images as a result of the filtering process. Unmanaged images cannot be hardware accelerated, and thus are typically much slower to draw. The best way to maximize performance is to ensure that all images are in one of the optimal formats. If you are unsure about a particular image, useImageUtilities#ensureIntRGBFormat(java.awt.image.BufferedImage).
- 
- 
Constructor SummaryConstructors Constructor Description AbstractImageFilter()
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static intclamp(float pixelByte)Clamps an input pixel value to a maximum of 255, converting it from float to int in the process.static intclamp(int pixelByte)Clamps an input pixel value to a maximum of 255.static intclamp(int value, int low, int high)Clamps an integer value to the range low..high inclusive.static intclampBoth(int pixelByte)Clamps an input pixel value to the range 0..255.java.awt.image.BufferedImagecreateCompatibleDestImage(java.awt.image.BufferedImage source, java.awt.image.ColorModel destinationColorModel)static floatfA(int argb)Returns the alpha component of a packed ARGB pixel as a float value between 0 and 1.static floatfB(int argb)Returns the blue component of a packed ARGB pixel as a float value between 0 and 1.static floatfG(int argb)Returns the green component of a packed ARGB pixel as a float value between 0 and 1.static floatfR(int argb)Returns the red component of a packed ARGB pixel as a float value between 0 and 1.static int[]getARGB(java.awt.image.BufferedImage image, int[] pixels)Stores the ARGB pixel data for an entire image in an array.static int[]getARGB(java.awt.image.BufferedImage image, int x, int y, int width, int height, int[] pixels)Fetches pixel data from an image in ARGB format.protected static int[]getARGBSynch(java.awt.image.BufferedImage image, int x, int y, int width, int height, int[] pixels)Fetches pixel data from an image in ARGB format.java.awt.geom.Rectangle2DgetBounds2D(java.awt.image.BufferedImage source)java.awt.geom.Point2DgetPoint2D(java.awt.geom.Point2D sourcePoint, java.awt.geom.Point2D destPoint)java.awt.RenderingHintsgetRenderingHints()static intiA(float a)Converts a floating point alpha value between 0 and 1 to a packed ARGB alpha value.static intiB(float b)Converts a floating point blue value between 0 and 1 to a packed ARGB blue value.static intiG(float g)Converts a floating point green value between 0 and 1 to a packed ARGB green value.static intiR(float r)Converts a floating point red value between 0 and 1 to a packed ARGB red value.static voidsetARGB(java.awt.image.BufferedImage image, int[] pixels)Replaces the data in an image with pixel values from an array.static voidsetARGB(java.awt.image.BufferedImage image, int x, int y, int width, int height, int[] pixels)Stores ARGB pixel data in an image.protected static voidsetARGBSynch(java.awt.image.BufferedImage image, int x, int y, int width, int height, int[] pixels)Stores ARGB pixel data in an image.
 
- 
- 
- 
Method Detail- 
createCompatibleDestImagepublic java.awt.image.BufferedImage createCompatibleDestImage(java.awt.image.BufferedImage source, java.awt.image.ColorModel destinationColorModel)- Specified by:
- createCompatibleDestImagein interface- java.awt.image.BufferedImageOp
 
 - 
getBounds2Dpublic java.awt.geom.Rectangle2D getBounds2D(java.awt.image.BufferedImage source) The base implementation returns the bounds of the image in image space; that is, the rectangle defined by 0, 0, source.getWidth(), source.getHeight().- Specified by:
- getBounds2Din interface- java.awt.image.BufferedImageOp
 
 - 
getPoint2Dpublic java.awt.geom.Point2D getPoint2D(java.awt.geom.Point2D sourcePoint, java.awt.geom.Point2D destPoint)The base implementation returns a copy of the original point. - Specified by:
- getPoint2Din interface- java.awt.image.BufferedImageOp
 
 - 
getRenderingHintspublic java.awt.RenderingHints getRenderingHints() The base implementation returns null.- Specified by:
- getRenderingHintsin interface- java.awt.image.BufferedImageOp
 
 - 
clampBothpublic static int clampBoth(int pixelByte) Clamps an input pixel value to the range 0..255.- Parameters:
- pixelByte- the pixel value
- Returns:
- max(0,min(pixelByte,255))
 
 - 
clamppublic static int clamp(int pixelByte) Clamps an input pixel value to a maximum of 255.- Parameters:
- pixelByte- the pixel value
- Returns:
- min(pixelByte,255)
 
 - 
clamppublic static int clamp(int value, int low, int high)Clamps an integer value to the range low..high inclusive.- Parameters:
- value- the value to clamp
- low- the minimum value
- high- the maximum value
- Returns:
- the clamped value
 
 - 
clamppublic static int clamp(float pixelByte) Clamps an input pixel value to a maximum of 255, converting it from float to int in the process.- Parameters:
- pixelByte- the pixel value
- Returns:
- min( (int) (pixelByte+0.5f),255)
 
 - 
fApublic static float fA(int argb) Returns the alpha component of a packed ARGB pixel as a float value between 0 and 1. This value is equivalent to the following calculation, (though possibly more efficient):(float) ((argb >> 24) & 0xff) / 255f - Parameters:
- argb- the 32-bit pixel value
- Returns:
- the alpha component as a unit value
 
 - 
fRpublic static float fR(int argb) Returns the red component of a packed ARGB pixel as a float value between 0 and 1. This value is equivalent to the following calculation, (though possibly more efficient):(float) ((argb >> 16) & 0xff) / 255f - Parameters:
- argb- the 32-bit pixel value
- Returns:
- the red component as a unit value
 
 - 
fGpublic static float fG(int argb) Returns the green component of a packed ARGB pixel as a float value between 0 and 1. This value is equivalent to the following calculation, (though possibly more efficient):(float) ((argb >> 8) & 0xff) / 255f - Parameters:
- argb- the 32-bit pixel value
- Returns:
- the green component as a unit value
 
 - 
fBpublic static float fB(int argb) Returns the blue component of a packed ARGB pixel as a float value between 0 and 1. This value is equivalent to the following calculation, (though possibly more efficient):(float) (argb & 0xff) / 255f - Parameters:
- argb- the 32-bit pixel value
- Returns:
- the blue component as a unit value
 
 - 
iApublic static int iA(float a) Converts a floating point alpha value between 0 and 1 to a packed ARGB alpha value. (The value is clamped to the range 0..255 and shifted left 24 bits.)- Parameters:
- a- the alpha component from 0 to 1
- Returns:
- a packed ARGB alpha value
 
 - 
iRpublic static int iR(float r) Converts a floating point red value between 0 and 1 to a packed ARGB red value. (The value is clamped to the range 0..255 and shifted left 16 bits.)- Parameters:
- r- the red component from 0 to 1
- Returns:
- a packed ARGB red value
 
 - 
iGpublic static int iG(float g) Converts a floating point green value between 0 and 1 to a packed ARGB green value. (The value is clamped to the range 0..255 and shifted left 8 bits.)- Parameters:
- g- the green component from 0 to 1
- Returns:
- a packed ARGB green value
 
 - 
iBpublic static int iB(float b) Converts a floating point blue value between 0 and 1 to a packed ARGB blue value. (The value is clamped to the range 0..255.)- Parameters:
- b- the blue component from 0 to 1
- Returns:
- a packed ARGB blue value
 
 - 
getARGBpublic static int[] getARGB(java.awt.image.BufferedImage image, int x, int y, int width, int height, int[] pixels)Fetches pixel data from an image in ARGB format. The data are converted from the source format, if required.- Parameters:
- image- the image to get pixels from
- x- the x-offset of the subimage
- y- the y-offset of the subimage
- width- the width of the subimage
- height- the height of the subimage
- pixels- an array to use; may be- null
- Returns:
- an array of pixel data for the subimage
 
 - 
getARGBSynchprotected static int[] getARGBSynch(java.awt.image.BufferedImage image, int x, int y, int width, int height, int[] pixels)Fetches pixel data from an image in ARGB format. The data are converted from the source format, if required. This method does not perform parallel processing.- Parameters:
- image- the image to get pixels from
- x- the x-offset of the subimage
- y- the y-offset of the subimage
- width- the width of the subimage
- height- the height of the subimage
- pixels- an array to use; may be- null
- Returns:
- an array of pixel data for the subimage
 
 - 
setARGBpublic static void setARGB(java.awt.image.BufferedImage image, int x, int y, int width, int height, int[] pixels)Stores ARGB pixel data in an image. The data are converted into the destination format, if required. This method may perform parallel processing.- Parameters:
- image- the image to set pixels on
- x- the x-offset of the subimage
- y- the y-offset of the subimage
- width- the width of the subimage
- height- the height of the subimage
- pixels- an array to use
 
 - 
setARGBSynchprotected static void setARGBSynch(java.awt.image.BufferedImage image, int x, int y, int width, int height, int[] pixels)Stores ARGB pixel data in an image. The data are converted into the destination format, if required. This method does not perform parallel processing.- Parameters:
- image- the image to set pixels on
- x- the x-offset of the subimage
- y- the y-offset of the subimage
- width- the width of the subimage
- height- the height of the subimage
- pixels- an array to use
 
 - 
getARGBpublic static int[] getARGB(java.awt.image.BufferedImage image, int[] pixels)Stores the ARGB pixel data for an entire image in an array. The data are converted from the source format, if required. This method may perform the copying in parallel depending on image size.- Parameters:
- image- the image to obtain a pixel array for
- pixels- the array to store the data in (may be null)
 
 - 
setARGBpublic static void setARGB(java.awt.image.BufferedImage image, int[] pixels)Replaces the data in an image with pixel values from an array. The data are converted into the destination format, if required. This method may perform the copying in parallel depending on image size.- Parameters:
- image- the image to set pixels on
- pixels- an array of source pixels
 
 
- 
 
-