/*
* Copyright 2005, 2009 Cosmin Basca.
* e-mail: cosmin.basca@gmail.com
*
* This 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; either version 2.1
* of the License, or (at your option) any later version.
*
* Please see COPYING for the complete licence.
*/
package robo.vision;
import java.awt.RenderingHints;
import java.awt.image.RenderedImage;
import java.awt.image.renderable.ParameterBlock;
import java.awt.image.renderable.RenderedImageFactory;
import javax.media.jai.ImageLayout;
import javax.media.jai.OperationDescriptorImpl;
public class HSISegmentDescriptor extends OperationDescriptorImpl implements RenderedImageFactory
{
/**
*
*/
private static final long serialVersionUID = -2191836024272331439L;
private static final String[][] resources = { {"GlobalName", "HSISegment"}, {"LocalName", "HSISegment"}, {"Vendor","edu.usf.csee"}, {"Description","HSISegment from an intensity image of a calibration object."}, {"DocURL",
""}, {"Version",""}, };
private static final String[] supportedModes = { "rendered" };
private static final int numSources = 1;
private static final String[] paramNames = { "aBins","bBins" };
@SuppressWarnings("unchecked")
private static final Class[] paramClasses = { java.lang.Integer.class, java.lang.Integer.class };
private static final Object[] paramDefaults = { new Integer(0), new Integer(0)};
/** Constructs a HSISegmentDescriptor.
*/
public HSISegmentDescriptor()
{
super(resources, supportedModes, numSources, paramNames, paramClasses, paramDefaults, null);
}
/** creates a HSISegmentOpImage.
* @param pb operation parameters (numbers of bins).
* @param hints result image rendering parameters.
* @return an instance of HSISegmentOpImage.
*/
public RenderedImage create(ParameterBlock pb, RenderingHints hints)
{
if (!validateParameters(pb))
{
return null;
}
return new HSISegmentOpImage(pb.getRenderedSource(0), new ImageLayout(), (Integer) pb.getObjectParameter(0), (Integer) pb.getObjectParameter(1));
}
/** validate the parameter types for this operation.
* @param pb the operation parameters.
* @return validation assessment (boolean)
*/
public boolean validateParameters(ParameterBlock pb)
{
return true;
}
//public String toString();
//public boolean equals(Object obj);
//protected Object clone() throws CloneNotSupportedException;
//protected void finalize() throws Throwable;
}