/* * Geotoolkit.org - An Open Source Java GIS Toolkit * http://www.geotoolkit.org * * (C) 2012, Geomatys * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; * version 2.1 of the License. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. */ package org.geotoolkit.image.iterator; import java.awt.Rectangle; import java.awt.image.Raster; import java.awt.image.RenderedImage; import java.awt.image.WritableRaster; import java.awt.image.WritableRenderedImage; /** * An Iterator for traversing anyone rendered Image. * <p> * Iteration transverse each tiles(raster) from rendered image or raster source one by one in order. * Iteration to follow tiles(raster) begin by raster bands, next, raster x coordinates, * and to finish raster y coordinates. * <p> * Iteration follow this scheme : * tiles band --> tiles x coordinates --> tiles y coordinates --> next rendered image tiles. * * Moreover iterator traversing a write or read each rendered image tiles(raster) in top-to-bottom, left-to-right order. * * Code example : * {@code * final DefaultWritableIterator dWRII = new DefaultWritableIterator(renderedImage); * while (dWRII.next()) { * dWRII.setSample(int value); * } * } * * @author RĂ©mi Marechal (Geomatys). * @author Martin Desruisseaux (Geomatys). */ class DefaultWritableIterator extends DefaultIterator { /** * Raster which is followed by iterator and wherein caller write. */ private WritableRaster currentWritableRaster; /** * Rendered image which is followed by iterator and wherein caller write. */ private WritableRenderedImage writableRenderedImage; /** * Current last x tile position in rendered image tile array. */ private int prectX; /** * Current last y tile position in rendered image tile array. */ private int prectY; /** * Create an appropriate iterator to read and write in a raster sub area. * * @param raster raster which is followed by read-only iterator. * @param writableRaster raster which is followed by this write-only iterator and wherein value is writing. * @param subArea Rectangle which represent raster sub area, wherein move read and write iterator. * @throws IllegalArgumentException if raster and writable raster dimensions are not conform. */ DefaultWritableIterator(final Raster raster, final WritableRaster writableRaster, final Rectangle subArea) { super(raster, subArea); checkRasters(raster, writableRaster, subArea); this.currentWritableRaster = writableRaster; } /** * Create an appropriate iterator to read and write in a rendered image sub area, tiles by tiles. * * @param renderedImage rendered image which is followed by read-only iterator. * @param writableRI writable rendered image which is followed by this write-only iterator and wherein value is writing. * @param subArea Rectangle which represent rendered image sub area, wherein move read and write iterator. * @throws IllegalArgumentException if renderedImage and writable renderedImage dimensions are not conform. * @throws IllegalArgumentException if renderedImage and writable renderedImage tiles configurations are not conform. */ DefaultWritableIterator(final RenderedImage renderedImage, final WritableRenderedImage writableRI, Rectangle subArea) { super(renderedImage, subArea); checkRenderedImage(renderedImage, writableRI, subArea); this.writableRenderedImage = writableRI; } /** * {@inheritDoc }. */ @Override public void rewind(){ currentWritableRaster = null; super.rewind(); } /** * {@inheritDoc }. */ @Override public void setSample(int value) { currentWritableRaster.setSample(x, y, band, value); } /** * {@inheritDoc }. */ @Override public void setSampleFloat(float value) { currentWritableRaster.setSample(x, y, band, value); } /** * {@inheritDoc }. */ @Override public void setSampleDouble(double value) { currentWritableRaster.setSample(x, y, band, value); } /** * {@inheritDoc }. */ @Override protected void updateCurrentRaster(int tileX, int tileY) { super.updateCurrentRaster(tileX, tileY); if (currentWritableRaster != null) writableRenderedImage.releaseWritableTile(prectX, prectY); this.currentWritableRaster = writableRenderedImage.getWritableTile(tileX, tileY); prectX = tileX; prectY = tileY; } /** * {@inheritDoc }. */ @Override public void close() { writableRenderedImage.releaseWritableTile(prectX, prectY); super.close(); } }