Package com.lightcrafts.media.jai.mlib

Source Code of com.lightcrafts.media.jai.mlib.MlibHistogramRIF

/*
* $RCSfile: MlibHistogramRIF.java,v $
*
* Copyright (c) 2005 Sun Microsystems, Inc. All rights reserved.
*
* Use is subject to license terms.
*
* $Revision: 1.2 $
* $Date: 2005/11/23 22:25:07 $
* $State: Exp $
*/package com.lightcrafts.media.jai.mlib;

import java.awt.Rectangle;
import java.awt.RenderingHints;
import java.awt.image.DataBuffer;
import java.awt.image.RenderedImage;
import java.awt.image.renderable.ParameterBlock;
import java.awt.image.renderable.RenderedImageFactory;
import com.lightcrafts.mediax.jai.ROI;
import com.lightcrafts.mediax.jai.util.ImagingListener;
import com.lightcrafts.media.jai.util.ImageUtil;

/**
* A <code>RIF</code> supporting the "Histogram" operation in the
* rendered image layer.
*
* @since EA2
* @see com.lightcrafts.mediax.jai.operator.HistogramDescriptor
* @see MlibHistogramOpImage
*/
public class MlibHistogramRIF implements RenderedImageFactory {

    /** Constructor. */
    public MlibHistogramRIF() {}

    /**
     * Creates a new instance of <code>MlibHistogramOpImage</code>
     * in the rendered layer. Any image layout information in
     * <code>RenderingHints</code> is ignored.
     * This method satisfies the implementation of RIF.
     */
    public RenderedImage create(ParameterBlock args,
                                RenderingHints hints) {

        // Return null of not mediaLib-compatible.
        if(!MediaLibAccessor.isMediaLibCompatible(args)) {
            return null;
        }

        // Return null if source data type is floating point.
        RenderedImage src = args.getRenderedSource(0);
        int dataType = src.getSampleModel().getDataType();
        if(dataType == DataBuffer.TYPE_FLOAT ||
           dataType == DataBuffer.TYPE_DOUBLE) {
            return null;
        }

        // Return null if ROI is non-null and not equals to source bounds.
        ROI roi = (ROI)args.getObjectParameter(0);
        if(roi != null &&
           !roi.equals(new Rectangle(src.getMinX(), src.getMinY(),
                                     src.getWidth(), src.getHeight()))) {
            return null;
        }

        // Get the non-ROI parameters.
        int xPeriod = args.getIntParameter(1);
        int yPeriod = args.getIntParameter(2);
        int[] numBins = (int[])args.getObjectParameter(3);
        double[] lowValueFP = (double[])args.getObjectParameter(4);
        double[] highValueFP = (double[])args.getObjectParameter(5);

        // Return null if lowValueFP or highValueFP is out of dataType range.
        int minPixelValue;
        int maxPixelValue;
        switch (dataType) {
        case DataBuffer.TYPE_SHORT:
            minPixelValue = Short.MIN_VALUE;
            maxPixelValue = Short.MAX_VALUE;
            break;
        case DataBuffer.TYPE_USHORT:
            minPixelValue = 0;
            maxPixelValue = -((int)Short.MIN_VALUE) + Short.MAX_VALUE;
            break;
        case DataBuffer.TYPE_INT:
            minPixelValue = Integer.MIN_VALUE;
            maxPixelValue = Integer.MAX_VALUE;
            break;
        case DataBuffer.TYPE_BYTE:
        default:
            minPixelValue = 0;
            maxPixelValue = -((int)Byte.MIN_VALUE) + Byte.MAX_VALUE;
            break;
        }
        for (int i = 0; i < lowValueFP.length; i++) {
            if (lowValueFP[i] < minPixelValue ||
                lowValueFP[i] > maxPixelValue) {
                return null;
            }
        }
        for (int i = 0; i < highValueFP.length; i++) {
            if (highValueFP[i] <= minPixelValue ||
                highValueFP[i] > (maxPixelValue + 1)) {
                return null;
            }
        }

        MlibHistogramOpImage op = null;
        try {
            op = new MlibHistogramOpImage(src,
                                          xPeriod, yPeriod,
                                          numBins, lowValueFP, highValueFP);
        } catch (Exception e) {
            ImagingListener listener = ImageUtil.getImagingListener(hints);
            String message = JaiI18N.getString("MlibHistogramRIF0");
            listener.errorOccurred(message, e, this, false);
        }

        return op;
    }
}
TOP

Related Classes of com.lightcrafts.media.jai.mlib.MlibHistogramRIF

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.