org.jaitools.imageutils.iterator.SimpleIterator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jt-all Show documentation
Show all versions of jt-all Show documentation
Provides a single jar containing all JAITools modules which you can
use instead of including individual modules in your project. Note:
It does not include the Jiffle scripting language or Jiffle image
operator.
/*
* Copyright (c) 2011, Michael Bedward. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* - Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* - Redistributions 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.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package org.jaitools.imageutils.iterator;
import java.awt.Rectangle;
import java.awt.image.RenderedImage;
import javax.media.jai.iterator.RectIter;
import javax.media.jai.iterator.RectIterFactory;
/**
* A read-only image iterator which moves by column then row (pixel then line).
*
* @author michael
*/
public class SimpleIterator extends AbstractSimpleIterator {
/**
* Provides a method to create the delegate iterator. Passing an instance of
* this class to the super-class constructor allows the delegate to be a
* final field in the super-class.
*/
private static class Helper implements DelegateHelper {
public RectIter create(RenderedImage image, Rectangle bounds) {
if (image == null) {
throw new IllegalArgumentException("image must not be null");
}
if (bounds == null || bounds.isEmpty()) {
return null;
}
return RectIterFactory.create(image, bounds);
}
}
/**
* Creates a new iterator. The bounds are allowed to extend beyond the bounds
* of the target image. When the iterator is positioned outside the image the
* specified outside value will be returned.
*
* @param image the target image
* @param bounds bounds for the iterator; if {@code null} the bounds of the target
* image will be used
* @param outsideValue value to return when the iterator is positioned beyond
* the bounds of the target image; may be {@code null}
*/
public SimpleIterator(RenderedImage image, Rectangle bounds, Number outsideValue) {
super(new Helper(), image, bounds, outsideValue, Order.IMAGE_X_Y);
}
/**
* Creates a new iterator. The bounds are allowed to extend beyond the bounds
* of the target image. When the iterator is positioned outside the image the
* specified outside value will be returned.
*
* @param image the target image
* @param bounds bounds for the iterator; if {@code null} the bounds of the target
* image will be used
* @param outsideValue value to return when the iterator is positioned beyond
* the bounds of the target image; may be {@code null}
* @param order processing order for this iterator when using the {@link #next()}
* method
*/
public SimpleIterator(RenderedImage image, Rectangle bounds,
Number outsideValue, Order order) {
super(new Helper(), image, bounds, outsideValue, order);
}
}