
org.monte.media.ilbm.ILBMImageReader Maven / Gradle / Ivy
/*
* @(#)ILBMImageReader.java
*
* Copyright (c) 2009 Werner Randelshofer, Goldau, Switzerland.
* All rights reserved.
*
* You may not use, copy or modify this file, except in compliance with the
* license agreement you entered into with Werner Randelshofer.
* For details see accompanying license terms.
*/
package org.monte.media.ilbm;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.LinkedList;
import javax.imageio.ImageReadParam;
import javax.imageio.ImageReader;
import javax.imageio.ImageTypeSpecifier;
import javax.imageio.metadata.IIOMetadata;
import javax.imageio.stream.ImageInputStream;
import org.monte.media.io.ImageInputStreamAdapter;
/**
* Reads an image in the Amiga IFF Interleaved Bitmap image format (ILBM).
*
* @author Werner Randelshofer
* @version $Id: ILBMImageReader.java 299 2013-01-03 07:40:18Z werner $
*/
public class ILBMImageReader extends ImageReader {
private ArrayList images = null;
public ILBMImageReader(ILBMImageReaderSpi originatingProvider) {
super(originatingProvider);
}
@Override
public int getNumImages(boolean allowSearch) throws IOException {
if (allowSearch && images == null) {
readImages();
}
return images.size();
}
@Override
public int getWidth(int imageIndex) throws IOException {
readImages();
return images.get(imageIndex).getWidth();
}
@Override
public int getHeight(int imageIndex) throws IOException {
readImages();
return images.get(imageIndex).getHeight();
}
@Override
public Iterator getImageTypes(int imageIndex) throws IOException {
readImages();
ColorCyclingMemoryImageSource iip = images.get(imageIndex);
LinkedList l = new LinkedList();
l.add(new ImageTypeSpecifier(iip.getColorModel(), //
iip.getColorModel().createCompatibleSampleModel(iip.getWidth(), iip.getHeight())));
return l.iterator();
}
/**
* Returns the aspect ratio of the given image (that is, its width
* divided by its height) as a float
. For images
* that are inherently resizable, this method provides a way to
* determine the appropriate width given a deired height, or vice
* versa. For non-resizable images, the true width and height
* are used.
*
* The default implementation simply returns
* (float)getWidth(imageIndex)/getHeight(imageIndex)
.
*
* @param imageIndex the index of the image to be queried.
*
* @return a float
indicating the aspect ratio of the
* given image.
*
* @exception IllegalStateException if the input source has not been set.
* @exception IndexOutOfBoundsException if the supplied index is
* out of bounds.
* @exception java.io.IOException if an error occurs during reading.
*/
@Override
public float getAspectRatio(int imageIndex) throws IOException {
readImages();
ColorCyclingMemoryImageSource mis=images.get(imageIndex);
float ratio = (float) getWidth(imageIndex) / getHeight(imageIndex);
if (mis.getProperties().containsKey("aspect")) {
ratio*=(Double)mis.getProperties().get("aspect");
}
return ratio;
}
@Override
public IIOMetadata getStreamMetadata() throws IOException {
return null;
}
@Override
public IIOMetadata getImageMetadata(int imageIndex) throws IOException {
return null;
}
@Override
public BufferedImage read(int imageIndex, ImageReadParam param)
throws IOException {
readImages();
return images.get(imageIndex).toBufferedImage();
}
private void readImages() throws IOException {
ImageInputStream in = (ImageInputStream) getInput();
if (images == null) {
in.seek(0);
ILBMDecoder d = new ILBMDecoder(new ImageInputStreamAdapter(in));
images = d.produce();
}
}
}