Medical Imaging Interaction Toolkit  2023.04.99-859410e3
Medical Imaging Interaction Toolkit
mitk::OtsuTool3D Class Reference

#include <mitkOtsuTool3D.h>

Inheritance diagram for mitk::OtsuTool3D:
Collaboration diagram for mitk::OtsuTool3D:

Public Member Functions

 mitkClassMacro (OtsuTool3D, SegWithPreviewTool)
Pointer Clone () const
const char * GetName () const override
 Returns the name of this tool. Make it short! More...
const char ** GetXPM () const override
 Returns an icon in the XPM format. More...
us::ModuleResource GetIconResource () const override
 Returns the tool button icon of the tool wrapped by a usModuleResource. More...
void Activated () override
 Called when the tool gets activated. More...
virtual void SetNumberOfBins (unsigned int _arg)
virtual unsigned int GetNumberOfBins () const
virtual void SetNumberOfRegions (unsigned int _arg)
virtual unsigned int GetNumberOfRegions () const
virtual void SetUseValley (bool _arg)
virtual bool GetUseValley () const
virtual void UseValleyOn ()
virtual void UseValleyOff ()
unsigned int GetMaxNumberOfBins () const
- Public Member Functions inherited from mitk::SegWithPreviewTool
 mitkClassMacro (SegWithPreviewTool, Tool)
void Activated () override
 Called when the tool gets activated. More...
void Deactivated () override
 Called when the tool gets deactivated. More...
void ConfirmSegmentation ()
virtual void SetCreateAllTimeSteps (bool _arg)
virtual bool GetCreateAllTimeSteps ()
virtual void CreateAllTimeStepsOn ()
virtual void CreateAllTimeStepsOff ()
virtual void SetKeepActiveAfterAccept (bool _arg)
virtual bool GetKeepActiveAfterAccept ()
virtual void KeepActiveAfterAcceptOn ()
virtual void KeepActiveAfterAcceptOff ()
virtual void SetIsTimePointChangeAware (bool _arg)
virtual bool GetIsTimePointChangeAware ()
virtual void IsTimePointChangeAwareOn ()
virtual void IsTimePointChangeAwareOff ()
virtual void SetResetsToEmptyPreview (bool _arg)
virtual bool GetResetsToEmptyPreview ()
virtual void ResetsToEmptyPreviewOn ()
virtual void ResetsToEmptyPreviewOff ()
virtual void SetUseSpecialPreviewColor (bool _arg)
virtual bool GetUseSpecialPreviewColor ()
virtual void UseSpecialPreviewColorOn ()
virtual void UseSpecialPreviewColorOff ()
void SetMergeStyle (MultiLabelSegmentation::MergeStyle mergeStyle)
virtual MultiLabelSegmentation::MergeStyle GetMergeStyle ()
void SetOverwriteStyle (MultiLabelSegmentation::OverwriteStyle overwriteStyle)
virtual MultiLabelSegmentation::OverwriteStyle GetOverwriteStyle ()
void SetLabelTransferScope (LabelTransferScope labelTransferScope)
virtual LabelTransferScope GetLabelTransferScope ()
void SetSelectedLabels (const SelectedLabelVectorType &labelsToTransfer)
virtual SelectedLabelVectorType GetSelectedLabels ()
void SetLabelTransferMode (LabelTransferMode labelTransferMode)
virtual LabelTransferMode GetLabelTransferMode ()
bool CanHandle (const BaseData *referenceData, const BaseData *workingData) const override
void UpdatePreview (bool ignoreLazyPreviewSetting=false)
bool IsUpdating () const
std::string GetCurrentSegmentationName ()
 Gets the name of the currently selected segmentation node. More...
virtual DataNodeGetTargetSegmentationNode () const
 Returns the currently selected segmentation node. More...
LabelSetImageGetTargetSegmentation () const
LabelSetImageGetPreviewSegmentation ()
const LabelSetImageGetPreviewSegmentation () const
DataNodeGetPreviewSegmentationNode ()
- Public Member Functions inherited from mitk::Tool
 mitkClassMacro (Tool, EventStateMachine)
virtual std::string GetIconPath () const
 Returns the path of an icon. More...
virtual us::ModuleResource GetCursorIconResource () const
 Returns the path of a cursor icon. More...
virtual void InitializeStateMachine ()
virtual itk::Object::Pointer GetGUI (const std::string &toolkitPrefix, const std::string &toolkitPostfix)
 Interface for GUI creation. More...
virtual NodePredicateBase::ConstPointer GetReferenceDataPreference () const
virtual NodePredicateBase::ConstPointer GetWorkingDataPreference () const
DataNode::Pointer CreateEmptySegmentationNode (const Image *original, const std::string &organName, const mitk::Color &color) const
DataNode::Pointer CreateSegmentationNode (Image *image, const std::string &organName, const mitk::Color &color) const
- Public Member Functions inherited from mitk::EventStateMachine
virtual std::vector< std::string > GetClassHierarchy () const override
virtual const char * GetClassName () const
bool LoadStateMachine (const std::string &filename, const us::Module *module=nullptr)
 Loads XML resource. More...
bool HandleEvent (InteractionEvent *event, DataNode *dataNode)
void EnableUndo (bool enable)
 Enables or disabled Undo. More...
void EnableInteraction (bool enable)
 Enables/disables the state machine. In un-enabled state it won't react to any events. More...
- Public Member Functions inherited from mitk::InteractionEventHandler
bool SetEventConfig (const std::string &filename, const us::Module *module=nullptr)
 Loads a configuration from an XML resource. More...
bool SetEventConfig (const EventConfig &config)
 Loads a configuration from an EventConfig object. More...
EventConfig GetEventConfig () const
 Returns the current configuration. More...
bool AddEventConfig (const std::string &filename, const us::Module *module=nullptr)
 This method extends the configuration. More...
bool AddEventConfig (const EventConfig &config)
 This method extends the configuration. The configuration from the EventConfig object is loaded and only the ones conflicting are replaced by the new one. This way several configurations can be combined. More...
- Public Member Functions inherited from mitk::InteractionEventObserver
 InteractionEventObserver ()
virtual ~InteractionEventObserver ()
void Disable ()
void Enable ()
bool IsEnabled () const

Static Public Member Functions

static Pointer New ()
- Static Public Member Functions inherited from mitk::EventStateMachine
static const char * GetStaticNameOfClass ()
- Static Public Member Functions inherited from mitk::InteractionEventHandler
static const char * GetStaticNameOfClass ()

Protected Member Functions

 OtsuTool3D ()
 ~OtsuTool3D ()=default
void UpdatePrepare () override
void DoUpdatePreview (const Image *inputAtTimeStep, const Image *oldSegAtTimeStep, LabelSetImage *previewImage, TimeStepType timeStep) override
- Protected Member Functions inherited from mitk::SegWithPreviewTool
 SegWithPreviewTool (bool lazyDynamicPreviews=false)
 SegWithPreviewTool (bool lazyDynamicPreviews, const char *interactorType, const us::Module *interactorModule=nullptr)
 ~SegWithPreviewTool () override
const char * GetGroup () const override
 Name of a group. More...
void EnsureTargetSegmentationNodeInDataStorage () const
virtual void InitiateToolByInput ()
virtual void UpdateCleanUp ()
virtual void PreparePreviewToResultTransfer (const LabelMappingType &labelMapping)
const ImageGetSegmentationInput () const
const ImageGetReferenceData () const
void ResetPreviewNode ()
void ResetPreviewContent ()
void ResetPreviewContentAtTimeStep (unsigned int timeStep)
TimePointType GetLastTimePointOfUpdate () const
LabelSetImage::LabelValueType GetActiveLabelValueOfPreview () const
virtual Label::PixelType GetUserDefinedActiveLabel () const
virtual void SetWorkingPlaneGeometry (PlaneGeometry *_arg)
virtual const PlaneGeometryGetWorkingPlaneGeometry ()
- Protected Member Functions inherited from mitk::Tool
virtual void SetToolManager (ToolManager *)
ToolManagerGetToolManager () const
mitk::DataStorageGetDataStorage () const
void ConnectActionsAndFunctions () override
 Tool (const char *, const us::Module *interactorModule=nullptr)
 ~Tool () override
void Notify (InteractionEvent *interactionEvent, bool isHandled) override
bool FilterEvents (InteractionEvent *, DataNode *) override
- Protected Member Functions inherited from mitk::EventStateMachine
 EventStateMachine ()
 ~EventStateMachine () override
void AddActionFunction (const std::string &action, TActionFunctor *functor)
void AddActionFunction (const std::string &action, const ActionFunctionDelegate &delegate)
void AddConditionFunction (const std::string &condition, const ConditionFunctionDelegate &delegate)
StateMachineStateGetCurrentState () const
void ResetToStartState ()
 ResetToStartState Reset state machine to it initial starting state. More...
virtual bool CheckCondition (const StateMachineCondition &condition, const InteractionEvent *interactionEvent)
virtual void ExecuteAction (StateMachineAction *action, InteractionEvent *interactionEvent)
void SetMouseCursor (const char *xpm[], int hotspotX, int hotspotY)
 Sets the specified mouse cursor. More...
void ResetMouseCursor ()
 Resets the mouse cursor to its original state. More...
StateMachineTransitionGetExecutableTransition (InteractionEvent *event)
 Returns the executable transition for the given event. More...
- Protected Member Functions inherited from mitk::InteractionEventHandler
 InteractionEventHandler ()
 ~InteractionEventHandler () override
PropertyList::Pointer GetAttributes () const
std::string MapToEventVariant (InteractionEvent *interactionEvent)
virtual void ConfigurationChanged ()

Protected Attributes

unsigned int m_NumberOfBins
unsigned int m_NumberOfRegions
bool m_UseValley
- Protected Attributes inherited from mitk::SegWithPreviewTool
ToolCommand::Pointer m_ProgressCommand
- Protected Attributes inherited from mitk::Tool
std::string m_EventConfig
 Let subclasses change their event configuration. More...
- Protected Attributes inherited from mitk::EventStateMachine
bool m_IsActive
bool m_UndoEnabled

Additional Inherited Members

- Public Types inherited from mitk::SegWithPreviewTool
enum  LabelTransferScope { LabelTransferScope::ActiveLabel, LabelTransferScope::SelectedLabels, LabelTransferScope::AllLabels }
enum  LabelTransferMode { LabelTransferMode::MapLabel, LabelTransferMode::AddLabel }
using SelectedLabelVectorType = std::vector< Label::PixelType >
- Public Types inherited from mitk::Tool
typedef mitk::Label::PixelType DefaultSegmentationDataType
- Public Types inherited from mitk::EventStateMachine
typedef EventStateMachine Self
typedef InteractionEventHandler Superclass
typedef itk::SmartPointer< SelfPointer
typedef itk::SmartPointer< const SelfConstPointer
typedef std::map< std::string, TActionFunctor * > ActionFunctionsMapType
typedef itk::SmartPointer< StateMachineStateStateMachineStateType
- Public Types inherited from mitk::InteractionEventHandler
typedef InteractionEventHandler Self
typedef itk::Object Superclass
typedef itk::SmartPointer< SelfPointer
typedef itk::SmartPointer< const SelfConstPointer
- Public Attributes inherited from mitk::Tool
Message GUIProcessEventsMessage
 To let GUI process new events (e.g. qApp->processEvents() ) More...
Message1< std::string > ErrorMessage
 To send error messages (to be shown by some GUI) More...
Message1< bool > CurrentlyBusy
 To send whether the tool is busy (to be shown by some GUI) More...
Message1< std::string > GeneralMessage
 To send general messages (to be shown by some GUI) More...
- Protected Types inherited from mitk::SegWithPreviewTool
using LabelMappingType = std::vector< std::pair< Label::PixelType, Label::PixelType > >
- Protected Types inherited from mitk::EventStateMachine
typedef MessageAbstractDelegate2< StateMachineAction *, InteractionEvent *, void > ActionFunctionDelegate
typedef MessageAbstractDelegate1< const InteractionEvent *, bool > ConditionFunctionDelegate
- Static Protected Member Functions inherited from mitk::SegWithPreviewTool
static Image::ConstPointer GetImageByTimeStep (const Image *image, TimeStepType timestep)
static Image::Pointer GetImageByTimeStep (Image *image, TimeStepType timestep)
static Image::ConstPointer GetImageByTimePoint (const Image *image, TimePointType timePoint)
static void TransferLabelInformation (const LabelMappingType &labelMapping, const mitk::LabelSetImage *source, mitk::LabelSetImage *target)
static void TransferLabelSetImageContent (const LabelSetImage *source, LabelSetImage *target, TimeStepType timeStep)

Detailed Description

Definition at line 27 of file mitkOtsuTool3D.h.

Constructor & Destructor Documentation

◆ OtsuTool3D()

mitk::OtsuTool3D::OtsuTool3D ( )

◆ ~OtsuTool3D()

mitk::OtsuTool3D::~OtsuTool3D ( )

Member Function Documentation

◆ Activated()

void mitk::OtsuTool3D::Activated ( )

Called when the tool gets activated.

Derived tools should call their parents implementation at the beginning of the overriding function.

Reimplemented from mitk::Tool.

◆ Clone()

Pointer mitk::OtsuTool3D::Clone ( ) const

◆ DoUpdatePreview()

void mitk::OtsuTool3D::DoUpdatePreview ( const Image inputAtTimeStep,
const Image oldSegAtTimeStep,
LabelSetImage previewImage,
TimeStepType  timeStep 

This function does the real work. Here the preview for a given input image should be computed and stored in the also passed preview image at the passed time step. It also provides the current/old segmentation at the time point, which can be used, if the preview depends on the the segmenation so far.

Implements mitk::SegWithPreviewTool.

◆ GetIconResource()

us::ModuleResource mitk::OtsuTool3D::GetIconResource ( ) const

Returns the tool button icon of the tool wrapped by a usModuleResource.

a valid ModuleResource or an invalid if this function is not reimplemented

Reimplemented from mitk::Tool.

◆ GetMaxNumberOfBins()

unsigned int mitk::OtsuTool3D::GetMaxNumberOfBins ( ) const

Returns the number of max bins based on the current input image.

◆ GetName()

const char* mitk::OtsuTool3D::GetName ( ) const

Returns the name of this tool. Make it short!

This name has to fit into some kind of button in most applications, so take some time to think of a good name!

Implements mitk::Tool.

◆ GetNumberOfBins()

virtual unsigned int mitk::OtsuTool3D::GetNumberOfBins ( ) const

◆ GetNumberOfRegions()

virtual unsigned int mitk::OtsuTool3D::GetNumberOfRegions ( ) const

◆ GetUseValley()

virtual bool mitk::OtsuTool3D::GetUseValley ( ) const

◆ GetXPM()

const char** mitk::OtsuTool3D::GetXPM ( ) const

Returns an icon in the XPM format.

This icon has to fit into some kind of button in most applications, so make it smaller than 25x25 pixels.

XPM is e.g. supported by The Gimp. But if you open any XPM file in your text editor, you will see that you could also "draw" it with an editor.

Implements mitk::Tool.

◆ mitkClassMacro()

mitk::OtsuTool3D::mitkClassMacro ( OtsuTool3D  ,

◆ New()

static Pointer mitk::OtsuTool3D::New ( )

◆ SetNumberOfBins()

virtual void mitk::OtsuTool3D::SetNumberOfBins ( unsigned int  _arg)

◆ SetNumberOfRegions()

virtual void mitk::OtsuTool3D::SetNumberOfRegions ( unsigned int  _arg)

◆ SetUseValley()

virtual void mitk::OtsuTool3D::SetUseValley ( bool  _arg)

◆ UpdatePrepare()

void mitk::OtsuTool3D::UpdatePrepare ( )

This member function offers derived classes the possibility to alter what should happen directly before the update of the preview is performed. It is called by UpdatePreview. Default implementation does nothing.

Reimplemented from mitk::SegWithPreviewTool.

◆ UseValleyOff()

virtual void mitk::OtsuTool3D::UseValleyOff ( )

◆ UseValleyOn()

virtual void mitk::OtsuTool3D::UseValleyOn ( )

Member Data Documentation

◆ m_NumberOfBins

unsigned int mitk::OtsuTool3D::m_NumberOfBins

Definition at line 60 of file mitkOtsuTool3D.h.

◆ m_NumberOfRegions

unsigned int mitk::OtsuTool3D::m_NumberOfRegions

Definition at line 61 of file mitkOtsuTool3D.h.

◆ m_UseValley

bool mitk::OtsuTool3D::m_UseValley

Definition at line 62 of file mitkOtsuTool3D.h.

The documentation for this class was generated from the following file: