- java.lang.Object
-
- javafx.scene.image.Image
-
- javafx.scene.image.WritableImage
-
public class WritableImage extends Image
TheWritableImageclass represents a custom graphical image that is constructed from pixels supplied by the application, and possibly fromPixelReaderobjects from any number of sources, including images read from a file or URL.- Since:
- JavaFX 2.2
-
-
Constructor Summary
Constructors Constructor Description WritableImage(int width, int height)Constructs an empty image of the specified dimensions.WritableImage(PixelBuffer<? extends Buffer> pixelBuffer)Constructs aWritableImageusing the specifiedPixelBuffer.WritableImage(PixelReader reader, int width, int height)Constructs an image of the specified dimensions, initialized from the indicatedPixelReader.WritableImage(PixelReader reader, int x, int y, int width, int height)Constructs an image of the specified dimensions, initialized from the indicated region of thePixelReader.
-
Method Summary
Modifier and Type Method Description PixelWritergetPixelWriter()This method returns aPixelWriterthat provides access to write the pixels of the image.-
Methods inherited from class javafx.scene.image.Image
cancel, errorProperty, exceptionProperty, getException, getHeight, getPixelReader, getProgress, getRequestedHeight, getRequestedWidth, getUrl, getWidth, heightProperty, isBackgroundLoading, isError, isPreserveRatio, isSmooth, progressProperty, widthProperty
-
-
-
-
Constructor Detail
-
WritableImage
public WritableImage(int width, int height)Constructs an empty image of the specified dimensions. The image will initially be filled with transparent pixels. Images constructed this way will always be readable and writable so the corresponding getPixelReader() and getPixelWriter() will always return valid objects. The dimensions must both be positive numbers(> 0).- Parameters:
width- the desired width of the writable imageheight- the desired height of the desired image- Throws:
IllegalArgumentException- if either dimension is negative or zero.
-
WritableImage
public WritableImage(PixelBuffer<? extends Buffer> pixelBuffer)
Constructs aWritableImageusing the specifiedPixelBuffer. TheBufferprovided by thePixelBufferwill be used directly as the pixel data for this image. ThePixelBuffercan be shared by multipleWritableImages. Images constructed this way are readable usingImage.getPixelReader(), but are not writable usingWritableImage.getPixelWriter().- Parameters:
pixelBuffer- thePixelBufferused to construct this image- Throws:
NullPointerException- ifpixelBufferisnull- Since:
- 13
-
WritableImage
public WritableImage(PixelReader reader, int width, int height)
Constructs an image of the specified dimensions, initialized from the indicatedPixelReader. The image will initially be filled with data returned from thePixelReader. If thePixelReaderaccesses a surface that does not contain the necessary number of pixel rows and columns then anArrayIndexOutOfBoundsExceptionwill be thrown. Images constructed this way will always be readable and writable so the corresponding getPixelReader() and getPixelWriter() will always return valid objects. The dimensions must both be positive numbers(> 0).- Parameters:
reader- thePixelReaderto construct fromwidth- the desired width of the writable image and the width of the region to be read from thereaderheight- the desired height of the desired image and the width of the region to be read from thereader- Throws:
ArrayIndexOutOfBoundsException- if thereaderdoes not access a surface of at least the requested dimensionsIllegalArgumentException- if either dimension is negative or zero.
-
WritableImage
public WritableImage(PixelReader reader, int x, int y, int width, int height)
Constructs an image of the specified dimensions, initialized from the indicated region of thePixelReader. The image will initially be filled with data returned from thePixelReaderfor the specified region. If thePixelReaderaccesses a surface that does not contain the necessary number of pixel rows and columns then anArrayIndexOutOfBoundsExceptionwill be thrown. Images constructed this way will always be readable and writable so the corresponding getPixelReader() and getPixelWriter() will always return valid objects. The dimensions must both be positive numbers(> 0).- Parameters:
reader- thePixelReaderto construct fromx- the X coordinate of the upper left corner of the region to read from thereadery- the Y coordinate of the upper left corner of the region to read from thereaderwidth- the desired width of the writable image and the width of the region to be read from thereaderheight- the desired height of the desired image and the width of the region to be read from thereader- Throws:
ArrayIndexOutOfBoundsException- if thereaderdoes not access a surface containing at least the indicated regionIllegalArgumentException- if either dimension is negative or zero.
-
-
Method Detail
-
getPixelWriter
public final PixelWriter getPixelWriter()
This method returns aPixelWriterthat provides access to write the pixels of the image. This method is not supported for images constructed using aPixelBuffer.- Returns:
- the
PixelWriterfor writing pixels to the image - Throws:
UnsupportedOperationException- if this image was created using aPixelBuffer
-
-