package net.coobird.thumbnailator.tasks; import java.awt.image.BufferedImage; import java.io.IOException; import net.coobird.thumbnailator.ThumbnailParameter; /** * This class is used by {@link ThumbnailTask} implementations which is used * when creating thumbnails from external sources and destinations. *
* If the image handled by a {@link ThumbnailTask} contains multiple images,
* only the first image will be read by the {@link #read()} method. Any
* subsequent images will be ignored.
*
* @param
* To be used for situtions where the output image format should be the
* same as the input image format.
*/
protected String inputFormatName;
/**
* Constant used to obtain the first image when reading an image file.
*/
protected static final int FIRST_IMAGE_INDEX = 0;
/**
* Instantiates a {@link ThumbnailTask} with the parameters to use when
* creating thumbnails.
*
* @param param The parameters to use when creating thumbnails.
* @throws NullPointerException If the parameter is {@code null}.
*/
protected ThumbnailTask(ThumbnailParameter param)
{
if (param == null)
{
throw new NullPointerException("The parameter is null.");
}
this.param = param;
}
/**
* Reads a source image.
*
* @return The image which was obtained from the source.
* @throws IOException Thrown when an I/O problem occurs when reading
* from the image source.
*/
/*
* Future changes note: The public interface of this method may have to be
* changed to support reading images tile-by-tile. This change may be
* required in order to support large images.
*/
public abstract BufferedImage read() throws IOException;
/**
* Writes the thumbnail to the destination.
*
* @param img The image to write.
* @throws UnsupportedFormatException When an image file which is to be
* read or written is unsupported.
* @throws IOException Thrown when an I/O problem occurs when writing the
* image.
*/
public abstract void write(BufferedImage img) throws IOException;
/**
* Returns the {@link ThumbnailParameter} for this {@link ThumbnailTask},
* used when performing a thumbnail generation operation.
*
* @return The parameters to use when generating thumbnails.
*/
public ThumbnailParameter getParam()
{
return param;
}
/**
* Returns the source from which the source image is retrieved or read.
*
* @return The source.
*/
public abstract S getSource();
/**
* Returns the destination to which the thumbnail is stored or written.
*
* @return The destination.
*/
public abstract D getDestination();
}
The class from which the image is retrieved or read.
* @param
{
/**
* The parameters to use when creating a thumbnail.
*/
protected final ThumbnailParameter param;
/**
* String indicating the image format of the input image.
*