org.eclipse.swt.graphics
Class ImageLoader

java.lang.Object
  extended byorg.eclipse.swt.graphics.ImageLoader

public class ImageLoader
extends java.lang.Object

Instances of this class are used to load images from, and save images to, a file or stream.

Currently supported image formats are:

ImageLoaders can be used to: NOTE that loading multiple images is platform-dependent.


Field Summary
 int backgroundPixel
          the background pixel for the logical screen (this corresponds to the GIF89a Background Color Index value).
 ImageData[] data
          the array of ImageData objects in this ImageLoader.
 int logicalScreenHeight
          the height of the logical screen on which the images reside, in pixels (this corresponds to the GIF89a Logical Screen Height value)
 int logicalScreenWidth
          the width of the logical screen on which the images reside, in pixels (this corresponds to the GIF89a Logical Screen Width value)
 int repeatCount
          the number of times to repeat the display of a sequence of animated images (this corresponds to the commonly-used GIF application extension for "NETSCAPE 2.0 01").
 
Constructor Summary
ImageLoader()
          Construct a new empty ImageLoader.
 
Method Summary
 ImageData[] load(java.io.InputStream stream)
          Loads an array of ImageData objects from the specified input stream.
 ImageData[] load(java.lang.String filename)
          Loads an array of ImageData objects from the file with the specified name.
 void save(java.io.OutputStream stream, int format)
          Saves the image data in this ImageLoader to the specified stream.
 void save(java.lang.String filename, int format)
          Saves the image data in this ImageLoader to a file with the specified name.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

data

public ImageData[] data
the array of ImageData objects in this ImageLoader. This array is read in when the load method is called, and it is written out when the save method is called


logicalScreenWidth

public int logicalScreenWidth
the width of the logical screen on which the images reside, in pixels (this corresponds to the GIF89a Logical Screen Width value)


logicalScreenHeight

public int logicalScreenHeight
the height of the logical screen on which the images reside, in pixels (this corresponds to the GIF89a Logical Screen Height value)


backgroundPixel

public int backgroundPixel
the background pixel for the logical screen (this corresponds to the GIF89a Background Color Index value). The default is -1 which means 'unspecified background'


repeatCount

public int repeatCount
the number of times to repeat the display of a sequence of animated images (this corresponds to the commonly-used GIF application extension for "NETSCAPE 2.0 01"). The default is 1. A value of 0 means 'display repeatedly'

Constructor Detail

ImageLoader

public ImageLoader()
Construct a new empty ImageLoader.

Method Detail

load

public ImageData[] load(java.io.InputStream stream)
Loads an array of ImageData objects from the specified input stream. Throws an error if either an error occurs while loading the images, or if the images are not of a supported type. Returns the loaded image data array.

Parameters:
stream - the input stream to load the images from
Returns:
an array of ImageData objects loaded from the specified input stream
Throws:
java.lang.IllegalArgumentException -
  • ERROR_NULL_ARGUMENT - if the stream is null
SWTException -
  • ERROR_INVALID_IMAGE - if the image file contains invalid data
  • ERROR_IO - if an input/output error occurs while reading data
  • ERROR_UNSUPPORTED_FORMAT - if the image file contains an unrecognized format
NOTE If multiple images are not supported, only one ImageData will be returned by this method.

load

public ImageData[] load(java.lang.String filename)
Loads an array of ImageData objects from the file with the specified name. Throws an error if either an error occurs while loading the images, or if the images are not of a supported type. Returns the loaded image data array.

Parameters:
filename - the name of the file to load the images from
Returns:
an array of ImageData objects loaded from the specified file
Throws:
java.lang.IllegalArgumentException -
  • ERROR_NULL_ARGUMENT - if the file name is null
SWTException -
  • ERROR_INVALID_IMAGE - if the image file contains invalid data
  • ERROR_IO - if an IO error occurs while reading data
  • ERROR_UNSUPPORTED_FORMAT - if the image file contains an unrecognized format
NOTE If multiple images are not supported, only one ImageData will be returned by this method.

save

public void save(java.io.OutputStream stream,
                 int format)
Saves the image data in this ImageLoader to the specified stream. The format parameter can have one of the following values:
IMAGE_GIF
GIF file format
IMAGE_JPEG
JPEG file format
IMAGE_PNG
PNG file format

Parameters:
stream - the output stream to write the images to
format - the format to write the images in
Throws:
java.lang.IllegalArgumentException -
  • ERROR_NULL_ARGUMENT - if the stream is null
SWTException -
  • ERROR_INVALID_IMAGE if the image data contains invalid data
  • ERROR_IO if an IO error occurs while writing to the file
  • ERROR_UNSUPPORTED_FORMAT - if the image file contains an unrecognized format

save

public void save(java.lang.String filename,
                 int format)
Saves the image data in this ImageLoader to a file with the specified name. The format parameter can have one of the following values:
IMAGE_GIF
GIF file format
IMAGE_JPEG
JPEG file format
IMAGE_PNG
PNG file format

Parameters:
filename - the name of the file to write the images to
format - the format to write the images in
Throws:
java.lang.IllegalArgumentException -
  • ERROR_NULL_ARGUMENT - if the file name is null
SWTException -
  • ERROR_INVALID_IMAGE if the image data contains invalid data
  • ERROR_IO if an IO error occurs while writing to the file
  • ERROR_UNSUPPORTED_FORMAT if the image data cannot be saved to the requested format