Class AreaAveragingScaleFilter
- All Implemented Interfaces:
ImageConsumer, Cloneable
This class extends the basic ImageFilter Class to scale an existing image and provide a source for a new image containing the resampled image. The pixels in the source image are blended to produce pixels for an image of the specified size. The blending process is analogous to scaling up the source image to a multiple of the destination size using pixel replication and then scaling it back down to the destination size by simply averaging all the pixels in the supersized image that fall within a given pixel of the destination image. If the data from the source is not delivered in TopDownLeftRight order then the filter will back off to a simple pixel replication behavior and utilize the requestTopDownLeftRightResend() method to refilter the pixels in a better way at the end.
It is meant to be used in conjunction with a FilteredImageSource object to produce scaled versions of existing images. Due to implementation dependencies, there may be differences in pixel values of an image filtered on different platforms.
- See Also:
-
Field Summary
Fields declared in class ReplicateScaleFilter
destHeight, destWidth, outpixbuf, srccols, srcHeight, srcrows, srcWidthModifier and TypeFieldDescriptionprotected intThe target height to scale the image.protected intThe target width to scale the image.protected ObjectAbytearray initialized with a size ofReplicateScaleFilter.destWidthand used to deliver a row of pixel data to theImageConsumer.protected int[]Anintarray containing information about a column of pixels.protected intThe height of the source image.protected int[]Anintarray containing information about a row of pixels.protected intThe width of the source image.Fields declared in class ImageFilter
consumerModifier and TypeFieldDescriptionprotected ImageConsumerThe consumer of the particular image data stream for which this instance of the ImageFilter is filtering data.Fields declared in interface ImageConsumer
COMPLETESCANLINES, IMAGEABORTED, IMAGEERROR, RANDOMPIXELORDER, SINGLEFRAME, SINGLEFRAMEDONE, SINGLEPASS, STATICIMAGEDONE, TOPDOWNLEFTRIGHTModifier and TypeFieldDescriptionstatic final intThe pixels will be delivered in (multiples of) complete scanlines at a time.static final intThe image creation process was deliberately aborted.static final intAn error was encountered while producing the image.static final intThe pixels will be delivered in a random order.static final intThe image contain a single static image.static final intOne frame of the image is complete but there are more frames to be delivered.static final intThe pixels will be delivered in a single pass.static final intThe image is complete and there are no more pixels or frames to be delivered.static final intThe pixels will be delivered in top-down, left-to-right order. -
Constructor Summary
ConstructorsConstructorDescriptionAreaAveragingScaleFilter(int width, int height) Constructs an AreaAveragingScaleFilter that scales the pixels from its source Image as specified by the width and height parameters. -
Method Summary
Modifier and TypeMethodDescriptionvoidsetHints(int hints) Detect if the data is being delivered with the necessary hints to allow the averaging algorithm to do its work.voidsetPixels(int x, int y, int w, int h, ColorModel model, byte[] pixels, int off, int scansize) Combine the components for the delivered byte pixels into the accumulation arrays and send on any averaged data for rows of pixels that are complete.voidsetPixels(int x, int y, int w, int h, ColorModel model, int[] pixels, int off, int scansize) Combine the components for the delivered int pixels into the accumulation arrays and send on any averaged data for rows of pixels that are complete.Methods declared in class ReplicateScaleFilter
setDimensions, setPropertiesModifier and TypeMethodDescriptionvoidsetDimensions(int w, int h) Override the dimensions of the source image and pass the dimensions of the new scaled size to the ImageConsumer.voidsetProperties(Hashtable<?, ?> props) Passes along the properties from the source object after adding a property indicating the scale applied.Methods declared in class ImageFilter
clone, getFilterInstance, imageComplete, resendTopDownLeftRight, setColorModelModifier and TypeMethodDescriptionclone()Clones this object.Returns a unique instance of an ImageFilter object which will actually perform the filtering for the specified ImageConsumer.voidimageComplete(int status) Filters the information provided in the imageComplete method of the ImageConsumer interface.voidResponds to a request for a TopDownLeftRight (TDLR) ordered resend of the pixel data from anImageConsumer.voidsetColorModel(ColorModel model) Filter the information provided in the setColorModel method of the ImageConsumer interface.Methods declared in class Object
equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitModifier and TypeMethodDescriptionbooleanIndicates whether some other object is "equal to" this one.protected voidfinalize()Deprecated, for removal: This API element is subject to removal in a future version.Finalization is deprecated and subject to removal in a future release.final Class<?> getClass()Returns the runtime class of thisObject.inthashCode()Returns a hash code value for this object.final voidnotify()Wakes up a single thread that is waiting on this object's monitor.final voidWakes up all threads that are waiting on this object's monitor.toString()Returns a string representation of the object.final voidwait()Causes the current thread to wait until it is awakened, typically by being notified or interrupted.final voidwait(long timeoutMillis) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.final voidwait(long timeoutMillis, int nanos) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.
-
Constructor Details
-
AreaAveragingScaleFilter
public AreaAveragingScaleFilter(int width, int height) Constructs an AreaAveragingScaleFilter that scales the pixels from its source Image as specified by the width and height parameters.- Parameters:
width- the target width to scale the imageheight- the target height to scale the image- Throws:
IllegalArgumentException- ifwidthequals zero orheightequals zero
-
-
Method Details
-
setHints
public void setHints(int hints) Detect if the data is being delivered with the necessary hints to allow the averaging algorithm to do its work.Note: This method is intended to be called by the
ImageProducerof theImagewhose pixels are being filtered. Developers using this class to filter pixels from an image should avoid calling this method directly since that operation could interfere with the filtering operation.- Specified by:
setHintsin interfaceImageConsumer- Overrides:
setHintsin classImageFilter- Parameters:
hints- a set of hints that the ImageConsumer uses to process the pixels- See Also:
-
setPixels
public void setPixels(int x, int y, int w, int h, ColorModel model, byte[] pixels, int off, int scansize) Combine the components for the delivered byte pixels into the accumulation arrays and send on any averaged data for rows of pixels that are complete. If the correct hints were not specified in the setHints call then relay the work to our superclass which is capable of scaling pixels regardless of the delivery hints.Note: This method is intended to be called by the
ImageProducerof theImagewhose pixels are being filtered. Developers using this class to filter pixels from an image should avoid calling this method directly since that operation could interfere with the filtering operation.- Specified by:
setPixelsin interfaceImageConsumer- Overrides:
setPixelsin classReplicateScaleFilter- Parameters:
x- the X coordinate of the upper-left corner of the area of pixels to be sety- the Y coordinate of the upper-left corner of the area of pixels to be setw- the width of the area of pixelsh- the height of the area of pixelsmodel- the specifiedColorModelpixels- the array of pixelsoff- the offset into thepixelsarrayscansize- the distance from one row of pixels to the next in thepixelsarray- See Also:
-
setPixels
public void setPixels(int x, int y, int w, int h, ColorModel model, int[] pixels, int off, int scansize) Combine the components for the delivered int pixels into the accumulation arrays and send on any averaged data for rows of pixels that are complete. If the correct hints were not specified in the setHints call then relay the work to our superclass which is capable of scaling pixels regardless of the delivery hints.Note: This method is intended to be called by the
ImageProducerof theImagewhose pixels are being filtered. Developers using this class to filter pixels from an image should avoid calling this method directly since that operation could interfere with the filtering operation.- Specified by:
setPixelsin interfaceImageConsumer- Overrides:
setPixelsin classReplicateScaleFilter- Parameters:
x- the X coordinate of the upper-left corner of the area of pixels to be sety- the Y coordinate of the upper-left corner of the area of pixels to be setw- the width of the area of pixelsh- the height of the area of pixelsmodel- the specifiedColorModelpixels- the array of pixelsoff- the offset into thepixelsarrayscansize- the distance from one row of pixels to the next in thepixelsarray- See Also:
-