| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You under the Apache License, Version 2.0 |
| * (the "License"); you may not use this file except in compliance with |
| * the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| /** |
| * @author Sergey I. Salishev |
| * @version $Revision: 1.2 $ |
| */ |
| |
| package javax.imageio; |
| |
| import java.awt.Dimension; |
| import java.awt.image.BufferedImage; |
| |
| /* |
| * @author Sergey I. Salishev |
| * @version $Revision: 1.2 $ |
| */ |
| |
| /** |
| * The ImageReadParam class provides information to the ImageReader about how an |
| * image is to be decoded. |
| * |
| * @since Android 1.0 |
| */ |
| public class ImageReadParam extends IIOParam { |
| |
| /** |
| * This flag indicates if this ImageReadParam supports setting the source |
| * rendering size. |
| */ |
| protected boolean canSetSourceRenderSize; |
| |
| /** |
| * The destination BufferedImage. |
| */ |
| protected BufferedImage destination; |
| |
| /** |
| * The destination bands. |
| */ |
| protected int[] destinationBands; |
| |
| /** |
| * The minimum progressive pass. |
| */ |
| protected int minProgressivePass; |
| |
| /** |
| * The number of progressive passes. |
| */ |
| protected int numProgressivePasses; |
| |
| /** |
| * The source render size. |
| */ |
| protected Dimension sourceRenderSize; |
| |
| /** |
| * Returns true if this ImageReaderParam supports rendering a source image |
| * at an arbitrary size. |
| * |
| * @return true, if this ImageReaderParam supports rendering a source image |
| * at an arbitrary size, false otherwise. |
| */ |
| public boolean canSetSourceRenderSize() { |
| return canSetSourceRenderSize; |
| } |
| |
| /** |
| * Gets the current destination image as BufferedImage. |
| * |
| * @return the BufferedImage which represents the destination. |
| */ |
| public BufferedImage getDestination() { |
| return destination; |
| } |
| |
| /** |
| * Gets the indices of destination bands. |
| * |
| * @return the array of destination bands. |
| */ |
| public int[] getDestinationBands() { |
| return destinationBands; |
| } |
| |
| /** |
| * Gets the index of the maximum pass to be decoded. This method returns |
| * Integer.MAX_VALUE, if getSourceNumProgressivePasses() method returns |
| * value that is equal to Integer.MAX_VALUE. Otherwise this method returns |
| * getSourceMinProgressivePass() + getSourceNumProgressivePasses() - 1. |
| * |
| * @return the index of the maximum pass to be decoded. |
| */ |
| public int getSourceMaxProgressivePass() { |
| if (getSourceNumProgressivePasses() == Integer.MAX_VALUE) { |
| return Integer.MAX_VALUE; |
| } |
| return getSourceMinProgressivePass() + getSourceNumProgressivePasses() - 1; |
| } |
| |
| /** |
| * Gets the index of the minimum progressive pass that is decoded, default |
| * is 0. |
| * |
| * @return the index of the minimum progressive pass that is decoded, |
| * default is 0. |
| */ |
| public int getSourceMinProgressivePass() { |
| return minProgressivePass; |
| } |
| |
| /** |
| * Gets the number of progressive passes. The default value is |
| * Integer.MAX_VALUE. |
| * |
| * @return the number of progressive passes. |
| */ |
| public int getSourceNumProgressivePasses() { |
| return numProgressivePasses; |
| } |
| |
| /** |
| * Gets the dimension of source image which will be rendered during decoding |
| * process. |
| * |
| * @return the source render size. |
| */ |
| public Dimension getSourceRenderSize() { |
| return sourceRenderSize; |
| } |
| |
| /** |
| * Sets the specified destination image. This image will be used by read, |
| * readAll, and readRaster methods, and a reference to it will be returned |
| * by those methods. |
| * |
| * @param destination |
| * the destination image. |
| */ |
| public void setDestination(BufferedImage destination) { |
| this.destination = destination; |
| } |
| |
| /** |
| * Sets the indices of the destination bands. |
| * |
| * @param destinationBands |
| * the indices of the destination bands. |
| */ |
| public void setDestinationBands(int[] destinationBands) { |
| this.destinationBands = destinationBands; |
| } |
| |
| @Override |
| public void setDestinationType(ImageTypeSpecifier destinationType) { |
| this.destinationType = destinationType; |
| } |
| |
| /** |
| * Sets the source progressive passes. |
| * |
| * @param minPass |
| * the index of the minimum pass to be decoded. |
| * @param numPasses |
| * the number of passes to be decoded. |
| */ |
| public void setSourceProgressivePasses(int minPass, int numPasses) { |
| minProgressivePass = minPass; |
| numProgressivePasses = numPasses; |
| } |
| |
| /** |
| * Sets the dimension size of source image if an image can be rendered at an |
| * arbitrary size. |
| * |
| * @param size |
| * the size of rendered image. |
| * @throws UnsupportedOperationException |
| * the unsupported operation exception. |
| */ |
| public void setSourceRenderSize(Dimension size) throws UnsupportedOperationException { |
| if (!canSetSourceRenderSize) { |
| throw new UnsupportedOperationException("can't set source renderer size"); |
| } |
| sourceRenderSize = size; |
| } |
| } |