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

org.monte.media.io.ImageOutputStreamAdapter Maven / Gradle / Ivy

There is a newer version: 1.1
Show newest version
/*
 * @(#)ImageOutputStreamAdapter.java  1.1  2011-01-07
 *
 * Copyright © 2010 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.io;

import java.io.FilterOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import javax.imageio.stream.ImageOutputStream;

/**
 * Adapts an {@code ImageOutputStream} for classes requiring an
 * {@code OutputStream}.
 *
 * @author Werner Randelshofer
 * @version 1.1 2011-01-07 Fixes performance.
 * 
1.0 2010-12-26 Created. */ public class ImageOutputStreamAdapter extends OutputStream { /** * The underlying output stream to be filtered. */ protected ImageOutputStream out; /** * Creates an output stream filter built on top of the specified * underlying output stream. * * @param out the underlying output stream to be assigned to * the field this.out for later use, or * null if this instance is to be * created without an underlying stream. */ public ImageOutputStreamAdapter(ImageOutputStream out) { this.out = out; } /** * Writes the specified byte to this output stream. *

* The write method of FilterOutputStream * calls the write method of its underlying output stream, * that is, it performs out.write(b). *

* Implements the abstract write method of OutputStream. * * @param b the byte. * @exception java.io.IOException if an I/O error occurs. */ @Override public void write(int b) throws IOException { out.write(b); } /** * Writes b.length bytes to this output stream. *

* The write method of FilterOutputStream * calls its write method of three arguments with the * arguments b, 0, and * b.length. *

* Note that this method does not call the one-argument * write method of its underlying stream with the single * argument b. * * @param b the data to be written. * @exception java.io.IOException if an I/O error occurs. * @see java.io.FilterOutputStream#write(byte[], int, int) */ @Override public void write(byte b[]) throws IOException { write(b, 0, b.length); } /** * Writes len bytes from the specified * byte array starting at offset off to * this output stream. *

* The write method of FilterOutputStream * calls the write method of one argument on each * byte to output. *

* Note that this method does not call the write method * of its underlying input stream with the same arguments. Subclasses * of FilterOutputStream should provide a more efficient * implementation of this method. * * @param b the data. * @param off the start offset in the data. * @param len the number of bytes to write. * @exception java.io.IOException if an I/O error occurs. * @see java.io.FilterOutputStream#write(int) */ @Override public void write(byte b[], int off, int len) throws IOException { out.write(b,off,len); } /** * Flushes this output stream and forces any buffered output bytes * to be written out to the stream. *

* The flush method of FilterOutputStream * calls the flush method of its underlying output stream. * * @exception java.io.IOException if an I/O error occurs. * @see java.io.FilterOutputStream#out */ @Override public void flush() throws IOException { out.flush(); } /** * Closes this output stream and releases any system resources * associated with the stream. *

* The close method of FilterOutputStream * calls its flush method, and then calls the * close method of its underlying output stream. * * @exception java.io.IOException if an I/O error occurs. * @see java.io.FilterOutputStream#flush() * @see java.io.FilterOutputStream#out */ @Override public void close() throws IOException { try { flush(); } finally { out.close(); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy