Class JDialogFuzzMinDeAndChatterji

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

public class JDialogFuzzMinDeAndChatterji extends JDialogScriptableBase implements AlgorithmInterface, ActionDiscovery, ScriptableActionInterface
Dialog to get user input, then call the algorithm. The user has the option to generate a new image or replace the source image. In addition the user can select having the algorithm applied to whole image or to the VOI regions. It should be noted that the algorithms are executed in their own thread.
Version:
1.0; 17 February 2000
See Also:
  • Field Details

    • image

      private ModelImage image
      DOCUMENT ME!
    • fuzzMinAlgo

      private AlgorithmFuzzMinDeAndChatterji fuzzMinAlgo
    • outputPanel

      private JPanelAlgorithmOutputOptions outputPanel
      DOCUMENT ME!
    • resultImage

      private ModelImage resultImage
      DOCUMENT ME!
    • titles

      private String[] titles
      DOCUMENT ME!
    • userInterface

      private ViewUserInterface userInterface
      DOCUMENT ME!
    • minVal

      private double minVal
    • maxVal

      private double maxVal
    • crossVal

      private double crossVal
    • labelgmin

      private JLabel labelgmin
    • textgmin

      private JTextField textgmin
    • gmin

      private double gmin
    • labelgmax

      private JLabel labelgmax
    • textgmax

      private JTextField textgmax
    • gmax

      private double gmax
    • labelSrcThreshold

      private JLabel labelSrcThreshold
    • textSrcThreshold

      private JTextField textSrcThreshold
    • srcThreshold

      private double srcThreshold
      Original image threshold
    • autoCheckBox

      private JCheckBox autoCheckBox
    • autoThreshold

      private boolean autoThreshold
      If true, ignore srcThreshold input and calculate best value
    • labelEnhancedThreshold

      private JLabel labelEnhancedThreshold
    • textEnhancedThreshold

      private JTextField textEnhancedThreshold
    • enhancedThreshold

      private double enhancedThreshold
      Enhanced image threshold
    • labelTheta1

      private JLabel labelTheta1
    • textTheta1

      private JTextField textTheta1
    • theta1

      private double theta1
      Angular equivalence of black band, 0 invalid input: '<'= theta1 invalid input: '<'= PI/2
    • labelTheta2

      private JLabel labelTheta2
    • textTheta2

      private JTextField textTheta2
    • theta2

      private double theta2
      Angular equivalence of white band, 0 invalid input: '<'= theta2 invalid input: '<'= PI/2
    • labelP1

      private JLabel labelP1
    • textP1

      private JTextField textP1
    • p1

      private double p1
      Black region exponent, 0 invalid input: '<'= p1 invalid input: '<'= 1.0
    • labelP2

      private JLabel labelP2
    • textP2

      private JTextField textP2
    • p2

      private double p2
      White region exponent, 0 invalid input: '<'= p2 invalid input: '<'= 1.0
  • Constructor Details

    • JDialogFuzzMinDeAndChatterji

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

      public JDialogFuzzMinDeAndChatterji(Frame theParentFrame, ModelImage im)
      Creates a new JDialogFuzzyMinimization object.
      Parameters:
      theParentFrame - Parent frame.
      im - Source image.
  • Method Details

    • actionPerformed

      public void actionPerformed(ActionEvent event)
      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 algorithm 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.
    • setSrcThreshold

      public void setSrcThreshold(double srcThreshold)
      Accessor that sets the srcThreshold value
      Parameters:
      srcThreshold -
    • setAutoThreshold

      public void setAutoThreshold(boolean autoThreshold)
      Accessor that sets the autoThreshold value
      Parameters:
      autoThreshold -
    • setEnhancedThreshold

      public void setEnhancedThreshold(double enhancedThreshold)
      Accessor that sets the enahncedThreshold value
      Parameters:
      enchancedThreshold -
    • setTheta1

      public void setTheta1(double theta1)
      Accessor that sets the theta1 value
      Parameters:
      theta1 -
    • setTheta2

      public void setTheta2(double theta2)
      Accessor that sets the theta2 value
      Parameters:
      theta2 -
    • setP1

      public void setP1(double p1)
      Accessor that sets the p1 value
      Parameters:
      p1 -
    • setP2

      public void setP2(double p2)
      Accessor that sets the p2 value
      Parameters:
      p2 -
    • setgmin

      public void setgmin(double gmin)
      Parameters:
      gmin -
    • setgmax

      public void setgmax(double gmax)
      Parameters:
      gmax -
    • callAlgorithm

      protected void callAlgorithm()
      Once all the necessary variables are set, call the median 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()
      Store the result image in the script runner's image table now that the action execution is finished.
      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.