/** * Copyright (C) 2008-2010 Daniel Senff * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ package de.danielsenff.imageflow.models.parameter; import java.util.HashMap; /** * Parameter Interface * @author Daniel Senff * */ public interface Parameter<T> { /** * Returns the Value of this Parameter * @return */ public abstract T getValue(); /** * Returns the default value of this Parameter * @return */ public abstract T getDefaultValue(); /** * Returns the name of the Parameter. * @return */ public String getDisplayName(); /* * Returns the type of the Parameter */ /** * @return */ public String getParaType(); /** * Get the help description of this Parameter. * @return */ public String getHelpString(); /** * @param parameterNumber */ public void setParameterNumber(final int parameterNumber); /** * Returns true if this parameter can not be changed. * @return */ public boolean isReadOnly(); public void setReadOnly(boolean readOnly); /** * Returns true, if this parameter should be generally invisible in the generated parameter forms. * This can not be overridden * @return */ public boolean isHidden(); public void setHidden(boolean b); /** * Special options hash to configure parameters more flexible. * @return */ public abstract HashMap<String, Object> getOptions(); /** * Adds a Parameter ChangeListener, that calls back on changes to the * parameter properties. * @param listener */ public void addParamChangeListener(ParamChangeListener listener); /** * Remove Parameter ChangeListener. * @param listener */ public void removeParamChangeListener(ParamChangeListener listener); }