All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.jaiimageio.jpeg2000.impl.IISRandomAccessIO Maven / Gradle / Ivy

Go to download

JPEG2000 support for Java Advanced Imaging Image I/O Tools API core. This module is licensed under the [JJ2000 license](LICENSE.txt) and is therefore NOT compatible with the GPL 3 license. It should be compatible with the LGPL 2.1 license.

There is a newer version: 1.4.0
Show newest version
/*
 * $RCSfile: IISRandomAccessIO.java,v $
 *
 * 
 * Copyright (c) 2006 Sun Microsystems, Inc. All  Rights Reserved.
 * 
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met: 
 * 
 * - Redistribution of source code must retain the above copyright 
 *   notice, this  list of conditions and the following disclaimer.
 * 
 * - Redistribution in binary form must reproduce the above copyright
 *   notice, this list of conditions and the following disclaimer in 
 *   the documentation and/or other materials provided with the
 *   distribution.
 * 
 * Neither the name of Sun Microsystems, Inc. or the names of 
 * contributors may be used to endorse or promote products derived 
 * from this software without specific prior written permission.
 * 
 * This software is provided "AS IS," without a warranty of any 
 * kind. ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND 
 * WARRANTIES, INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, 
 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE HEREBY
 * EXCLUDED. SUN MIDROSYSTEMS, INC. ("SUN") AND ITS LICENSORS SHALL 
 * NOT BE LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF 
 * USING, MODIFYING OR DISTRIBUTING THIS SOFTWARE OR ITS
 * DERIVATIVES. IN NO EVENT WILL SUN OR ITS LICENSORS BE LIABLE FOR 
 * ANY LOST REVENUE, PROFIT OR DATA, OR FOR DIRECT, INDIRECT, SPECIAL,
 * CONSEQUENTIAL, INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER CAUSED AND
 * REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF THE USE OF OR
 * INABILITY TO USE THIS SOFTWARE, EVEN IF SUN HAS BEEN ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGES. 
 * 
 * You acknowledge that this software is not designed or intended for 
 * use in the design, construction, operation or maintenance of any 
 * nuclear facility. 
 *
 * $Revision: 1.1 $
 * $Date: 2006/08/08 00:31:47 $
 * $State: Exp $
 */
package com.github.jaiimageio.jpeg2000.impl;

import java.io.IOException;
import java.nio.ByteOrder;

import javax.imageio.stream.ImageInputStream;

import jj2000.j2k.io.EndianType;
import jj2000.j2k.io.RandomAccessIO;

/**
 * A wrapper for converting an ImageInputStream into a
 * RandomAccessIO. The resulting class is read-only.
 */
public class IISRandomAccessIO implements RandomAccessIO {

    /** The ImageInputStream that is wrapped */
    private ImageInputStream iis;

    /**
     * Creates a RandomAccessIO instance from the supplied
     * ImageInputStream.
     *
     * @param iis The source ImageInputStream.
     */
    public IISRandomAccessIO(ImageInputStream iis) {
        if (iis == null) {
            throw new IllegalArgumentException("iis == null!");
        }
        this.iis = iis;
    }

    public void close() throws IOException {
        iis.close();
    }

    /**
     * Returns the stream position clamped to a maximum of
     * Integer.MAX_VALUE.
     */
    public int getPos() throws IOException {
        long pos = iis.getStreamPosition();
        return pos > Integer.MAX_VALUE ? Integer.MAX_VALUE : (int)pos;
    }

    public void seek(int off) throws IOException {
        iis.seek(off);
    }

    /**
     * Returns the length of the data stream.
     *
     * 

If the length of the ImageInputStream is not * -1, then it is returned after being clamped to * a maximum value of Integer.MAX_VALUE. If the * ImageInputStream is -1, the stream * is read to a maximum position of Integer.MAX_VALUE * and its final position is returned. The position of the stream * is unchanged from the value it had prior to the call.

*/ public int length() throws IOException { long len = iis.length(); // If the length is non-negative, use it. if(len != -1L) { return len > Integer.MAX_VALUE ? Integer.MAX_VALUE : (int)len; } // If the length is negative, read until the stream ends. iis.mark(); int bufLen = 1024; byte[] buf = new byte[bufLen]; long pos = iis.getStreamPosition(); while(pos < Integer.MAX_VALUE) { int numRead = iis.read(buf, 0, bufLen); if(numRead == -1) break; // EOF pos += numRead; } iis.reset(); // Return the last position. return pos > Integer.MAX_VALUE ? Integer.MAX_VALUE : (int)pos; } public int read() throws IOException { return iis.read(); } public void readFully(byte b[], int off, int n) throws IOException { iis.readFully(b, off, n); } public int getByteOrdering() { return iis.getByteOrder() == ByteOrder.BIG_ENDIAN ? EndianType.BIG_ENDIAN : EndianType.LITTLE_ENDIAN; } public byte readByte() throws IOException { return iis.readByte(); } public int readUnsignedByte() throws IOException { return iis.readUnsignedByte(); } public short readShort() throws IOException { return iis.readShort(); } public int readUnsignedShort() throws IOException { return iis.readUnsignedShort(); } public int readInt() throws IOException { return iis.readInt(); } public long readUnsignedInt() throws IOException { return iis.readUnsignedInt(); } public long readLong() throws IOException { return iis.readLong(); } public float readFloat() throws IOException { return iis.readFloat(); } public double readDouble() throws IOException { return iis.readDouble(); } public int skipBytes(int n) throws IOException { return iis.skipBytes(n); } /** * A null operation as writing is not supported. */ public void flush() { // Intentionally empty. } /** * Throws an IOException as writing is not supported. */ public void write(int b) throws IOException { throw new IOException("Writing is not supported!"); } /** * Throws an IOException as writing is not supported. */ public void writeByte(int v) throws IOException { throw new IOException("Writing is not supported!"); } /** * Throws an IOException as writing is not supported. */ public void writeShort(int v) throws IOException { throw new IOException("Writing is not supported!"); } /** * Throws an IOException as writing is not supported. */ public void writeInt(int v) throws IOException { throw new IOException("Writing is not supported!"); } /** * Throws an IOException as writing is not supported. */ public void writeLong(long v) throws IOException { throw new IOException("Writing is not supported!"); } /** * Throws an IOException as writing is not supported. */ public void writeFloat(float v) throws IOException { throw new IOException("Writing is not supported!"); } /** * Throws an IOException as writing is not supported. */ public void writeDouble(double v) throws IOException { throw new IOException("Writing is not supported!"); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy