Class JDialogWaveletThreshold

All Implemented Interfaces:
AlgorithmInterface, ScriptableActionInterface, DialogDefaultsInterface, ActionDiscovery, ActionListener, FocusListener, ItemListener, WindowListener, ImageObserver, MenuContainer, Serializable, EventListener, Accessible, RootPaneContainer, WindowConstants

public class JDialogWaveletThreshold extends JDialogScriptableBase implements AlgorithmInterface, ActionDiscovery, ScriptableActionInterface
DOCUMENT ME!
See Also:
  • Field Details

    • serialVersionUID

      private static final long serialVersionUID
      Use serialVersionUID for interoperability.
      See Also:
    • DAUB4

      public static final int DAUB4
      underlying wavelet filter For 4 coefficients the routine daub4 is considerably faster than pwt. DAUB4 implements a Daubechies 4-coefficient wavelet filter. PWT implements Daubechies filters with 4, 12, and 20 coefficients. DAUB4 and PWT use different default centerings. In spite of the faster speed of DAUB4, the dialog is designed only to call PWT so that that user only sees changes due to the number of coefficients and is not confused by changes in centering.
      See Also:
    • PWT

      public static final int PWT
      DOCUMENT ME!
      See Also:
    • HARD

      public static final int HARD
      thresholding estimator.
      See Also:
    • SOFT

      public static final int SOFT
      DOCUMENT ME!
      See Also:
    • NONNEGATIVE_GARROTE

      public static final int NONNEGATIVE_GARROTE
      DOCUMENT ME!
      See Also:
    • SCAD

      public static final int SCAD
      DOCUMENT ME!
      See Also:
    • cNum

      private int cNum
      or if the source image is to be replaced.
    • coefficientCombo

      private JComboBox coefficientCombo
      DOCUMENT ME!
    • displayLoc

      private int displayLoc
      DOCUMENT ME!
    • doWaveletImage

      private boolean doWaveletImage
      DOCUMENT ME!
    • garrote

      private JRadioButton garrote
      DOCUMENT ME!
    • hard

      private JRadioButton hard
      DOCUMENT ME!
    • image

      private ModelImage image
      DOCUMENT ME!
    • newImage

      private JRadioButton newImage
      DOCUMENT ME!
    • replaceImage

      private JRadioButton replaceImage
      DOCUMENT ME!
    • resultImage

      private ModelImage resultImage
      DOCUMENT ME!
    • scad

      private JRadioButton scad
      DOCUMENT ME!
    • soft

      private JRadioButton soft
      DOCUMENT ME!
    • textThreshold

      private JTextField textThreshold
      DOCUMENT ME!
    • threshold

      private float threshold
      DOCUMENT ME!
    • thresholdType

      private int thresholdType
      DOCUMENT ME!
    • titles

      private String[] titles
      DOCUMENT ME!
    • userInterface

      private ViewUserInterface userInterface
      DOCUMENT ME!
    • waveletAlgo

      private AlgorithmWaveletThreshold waveletAlgo
      DOCUMENT ME!
    • waveletCheckBox

      private JCheckBox waveletCheckBox
      DOCUMENT ME!
    • waveletImage

      private ModelImage waveletImage
      DOCUMENT ME!
  • Constructor Details

    • JDialogWaveletThreshold

      public JDialogWaveletThreshold()
      Empty constructor needed for dynamic instantiation (used during scripting).
    • JDialogWaveletThreshold

      public JDialogWaveletThreshold(Frame theParentFrame, ModelImage im)
      Creates new dialog for entering parameters for wavelet threshold.
      Parameters:
      theParentFrame - Parent frame
      im - Source image
  • Method Details

    • actionPerformed

      public void actionPerformed(ActionEvent event)
      actionPerformed - Closes dialog box when the OK button is pressed and calls the algorithm.
      Specified by:
      actionPerformed in interface ActionListener
      Overrides:
      actionPerformed in class JDialogBase
      Parameters:
      event - event that triggers function
    • algorithmPerformed

      public void algorithmPerformed(AlgorithmBase algorithm)
      This method is required if the AlgorithmPerformed interface is implemented. It is called by the algorithms when it has completed or failed to to complete, so that the dialog can be display the result image and/or clean up.
      Specified by:
      algorithmPerformed in interface AlgorithmInterface
      Parameters:
      algorithm - Algorithm that caused the event.
    • getResultImage

      public ModelImage getResultImage()
      Accessor that returns the image.
      Returns:
      the result image
    • itemStateChanged

      public void itemStateChanged(ItemEvent event)
      Method to handle item events.
      Specified by:
      itemStateChanged in interface ItemListener
      Overrides:
      itemStateChanged in class JDialogBase
      Parameters:
      event - event that cause the method to fire
    • setCNum

      public void setCNum(int cNum)
      Accessor that sets the number of terms.
      Parameters:
      cNum - DOCUMENT ME!
    • setDisplayLocNew

      public void setDisplayLocNew()
      Accessor that sets the display loc variable to new, so that a new image is created once the algorithm completes.
    • setDisplayLocReplace

      public void setDisplayLocReplace()
      Accessor that sets the display loc variable to replace, so the current image is replaced once the algorithm completes.
    • setDoWaveletImage

      public void setDoWaveletImage(boolean doWaveletImage)
      Accessor that sets whether or not the wavelet image is displayed.
      Parameters:
      doWaveletImage - DOCUMENT ME!
    • setThreshold

      public void setThreshold(float threshold)
      Accessor that sets the threshold.
      Parameters:
      threshold - DOCUMENT ME!
    • setThresholdType

      public void setThresholdType(int thresholdType)
      Accessor that sets whether soft or hard thresholding is used.
      Parameters:
      thresholdType - DOCUMENT ME!
    • callAlgorithm

      protected void callAlgorithm()
      Once all the necessary variables are set, call the UnsharpMark algorithm based on what type of image this is and whether or not there is a separate destination image.
      Specified by:
      callAlgorithm in class JDialogScriptableBase
    • doPostAlgorithmActions

      protected void doPostAlgorithmActions()
      Used to perform actions after the execution of the algorithm is completed (e.g., put the result image in the image table). Defaults to no action, override to actually have it do something.
      Overrides:
      doPostAlgorithmActions in class JDialogScriptableBase
    • setGUIFromParams

      protected void setGUIFromParams()
      Set the dialog GUI using the script parameters while running this algorithm as part of a script.
      Specified by:
      setGUIFromParams in class JDialogScriptableBase
    • storeParamsFromGUI

      protected void storeParamsFromGUI() throws ParserException
      Record the parameters just used to run this algorithm in a script.
      Specified by:
      storeParamsFromGUI in class JDialogScriptableBase
      Throws:
      ParserException - If there is a problem creating/recording the new parameters.
    • init

      private void init()
      Sets up the GUI (panels, buttons, etc) and displays it on the screen.
    • setVariables

      private boolean setVariables()
      Use the GUI results to set up the variables needed to run the algorithm.
      Returns:
      true if parameters set successfully, false otherwise.
    • getActionMetadata

      public ActionMetadata getActionMetadata()
      Return meta-information about this discoverable action for categorization and labeling purposes.
      Specified by:
      getActionMetadata in interface ActionDiscovery
      Returns:
      Metadata for this action.
    • createInputParameters

      public ParameterTable createInputParameters()
      Returns a table listing the input parameters of this algorithm (which should match up with the scripting parameters used in setGUIFromParams()).
      Specified by:
      createInputParameters in interface ActionDiscovery
      Returns:
      A parameter table listing the inputs of this algorithm.
    • createOutputParameters

      public ParameterTable createOutputParameters()
      Returns a table listing the output parameters of this algorithm (usually just labels used to obtain output image names later).
      Specified by:
      createOutputParameters in interface ActionDiscovery
      Returns:
      A parameter table listing the outputs of this algorithm.
    • getOutputImageName

      public String getOutputImageName(String imageParamName)
      Returns the name of an image output by this algorithm, the image returned depends on the parameter label given (which can be used to retrieve the image object from the image registry).
      Specified by:
      getOutputImageName in interface ActionDiscovery
      Parameters:
      imageParamName - The output image parameter label for which to get the image name.
      Returns:
      The image name of the requested output image parameter label.
    • isActionComplete

      public boolean isActionComplete()
      Returns whether the action has successfully completed its execution.
      Specified by:
      isActionComplete in interface ActionDiscovery
      Returns:
      True, if the action is complete. False, if the action failed or is still running.