Medical Imaging Interaction Toolkit
2023.12.00
Medical Imaging Interaction Toolkit
|
Abstract base class for segmentation tools. More...
#include <mitkSegTool2D.h>
Classes | |
struct | SliceInformation |
Public Member Functions | |
mitkClassMacro (SegTool2D, Tool) | |
void | SetShowMarkerNodes (bool) |
void | SetEnable3DInterpolation (bool) |
Enables or disables the 3D interpolation after writing back the 2D segmentation result, and defaults to true. More... | |
void | Activated () override |
Called when the tool gets activated. More... | |
void | Deactivated () override |
Called when the tool gets deactivated. More... | |
virtual void | SetIsTimePointChangeAware (bool _arg) |
virtual bool | GetIsTimePointChangeAware () |
virtual void | IsTimePointChangeAwareOn () |
virtual void | IsTimePointChangeAwareOff () |
![]() | |
mitkClassMacro (Tool, EventStateMachine) | |
virtual const char ** | GetXPM () const =0 |
Returns an icon in the XPM format. More... | |
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 us::ModuleResource | GetIconResource () const |
Returns the tool button icon of the tool wrapped by a usModuleResource. More... | |
virtual const char * | GetName () const =0 |
Returns the name of this tool. Make it short! More... | |
virtual const char * | GetGroup () const |
Name of a group. 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 |
virtual bool | CanHandle (const BaseData *referenceData, const BaseData *workingData) const |
![]() | |
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... | |
![]() | |
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... | |
![]() | |
InteractionEventObserver () | |
virtual | ~InteractionEventObserver () |
void | Disable () |
void | Enable () |
bool | IsEnabled () const |
Static Public Member Functions | |
static bool | DetermineAffectedImageSlice (const Image *image, const PlaneGeometry *plane, int &affectedDimension, int &affectedSlice) |
Calculates for a given Image and PlaneGeometry, which slice of the image (in index corrdinates) is meant by the plane. More... | |
static void | UpdateSurfaceInterpolation (const Image *slice, const Image *workingImage, const PlaneGeometry *plane, bool detectIntersection) |
Updates the surface interpolation by extracting the contour form the given slice. More... | |
static Image::Pointer | GetAffectedImageSliceAs2DImage (const InteractionPositionEvent *positionEvent, const Image *image, unsigned int component=0) |
Extract the slice of an image that the user just scribbles on. The given component denotes the vector component of an vector image. More... | |
static Image::Pointer | GetAffectedImageSliceAs2DImage (const PlaneGeometry *planeGeometry, const Image *image, TimeStepType timeStep, unsigned int component=0) |
Extract the slice of an image cut by given plane. The given component denotes the vector component of a vector image. More... | |
static Image::Pointer | GetAffectedImageSliceAs2DImageByTimePoint (const PlaneGeometry *planeGeometry, const Image *image, TimePointType timePoint, unsigned int component=0) |
static void | WriteBackSegmentationResult (const DataNode *workingNode, const PlaneGeometry *planeGeometry, const Image *segmentationResult, TimeStepType timeStep) |
static void | WriteSliceToVolume (Image *workingImage, const PlaneGeometry *planeGeometry, const Image *slice, TimeStepType timeStep, bool allowUndo) |
![]() | |
static const char * | GetStaticNameOfClass () |
![]() | |
static const char * | GetStaticNameOfClass () |
Protected Member Functions | |
SegTool2D () | |
SegTool2D (const char *, const us::Module *interactorModule=nullptr) | |
~SegTool2D () override | |
DataNode * | GetWorkingDataNode () const |
returns the segmentation node that should be modified by the tool. More... | |
Image * | GetWorkingData () const |
DataNode * | GetReferenceDataNode () const |
Image * | GetReferenceData () const |
virtual void | OnTimePointChanged () |
bool | FilterEvents (InteractionEvent *interactionEvent, DataNode *dataNode) override |
Filters events that cannot be handled by 2D segmentation tools. More... | |
Image::Pointer | GetAffectedWorkingSlice (const InteractionPositionEvent *) const |
Extract the slice of the currently selected working image that the user just scribbles on. More... | |
Image::Pointer | GetAffectedReferenceSlice (const InteractionPositionEvent *) const |
Extract the slice of the currently selected reference image that the user just scribbles on. More... | |
Image::Pointer | GetAffectedReferenceSlice (const PlaneGeometry *planeGeometry, TimeStepType timeStep) const |
void | WriteBackSegmentationResult (const InteractionPositionEvent *, const Image *segmentationResult) |
void | WriteBackSegmentationResult (const PlaneGeometry *planeGeometry, const Image *segmentationResult, TimeStepType timeStep) |
void | WriteBackSegmentationResults (const std::vector< SliceInformation > &sliceList, bool writeSliceToVolume=true) |
int | AddContourmarker (const PlaneGeometry *planeGeometry, unsigned int sliceIndex) |
Adds a new node called Contourmarker to the datastorage which holds a mitk::PlanarFigure. By selecting this node the slicestack will be reoriented according to the passed PlanarFigure's Geometry. More... | |
void | InteractiveSegmentationBugMessage (const std::string &message) const |
virtual TimePointType | GetLastTimePointTriggered () |
![]() | |
virtual void | SetToolManager (ToolManager *) |
ToolManager * | GetToolManager () const |
mitk::DataStorage * | GetDataStorage () 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 |
![]() | |
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) |
StateMachineState * | GetCurrentState () 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... | |
StateMachineTransition * | GetExecutableTransition (InteractionEvent *event) |
Returns the executable transition for the given event. More... | |
![]() | |
InteractionEventHandler () | |
~InteractionEventHandler () override | |
PropertyList::Pointer | GetAttributes () const |
std::string | MapToEventVariant (InteractionEvent *interactionEvent) |
virtual void | ConfigurationChanged () |
Static Protected Member Functions | |
static void | UpdateSurfaceInterpolation (const std::vector< SliceInformation > &sliceInfos, const Image *workingImage, bool detectIntersection, unsigned int activeLayerID, mitk::Label::PixelType activeLabelValue) |
Updates the surface interpolation by extracting the contour form the given slice. More... | |
static void | WriteBackSegmentationResults (const DataNode *workingNode, const std::vector< SliceInformation > &sliceList, bool writeSliceToVolume=true) |
Writes all provided source slices into the data of the passed workingNode. The function does the following: 1) for every passed slice write it to workingNode (and generate and undo/redo step); 2) update the surface interpolation and 3) mark the node as modified. More... | |
static void | WritePreviewOnWorkingImage (Image *targetSlice, const Image *sourceSlice, const Image *workingImage, int paintingPixelValue) |
static void | WriteSliceToVolume (Image *workingImage, const SliceInformation &sliceInfo, bool allowUndo) |
static bool | IsPositionEventInsideImageRegion (InteractionPositionEvent *positionEvent, const BaseData *data) |
Protected Attributes | |
BaseRenderer * | m_LastEventSender |
unsigned int | m_LastEventSlice |
![]() | |
std::string | m_EventConfig |
Let subclasses change their event configuration. More... | |
![]() | |
bool | m_IsActive |
UndoController * | m_UndoController |
bool | m_UndoEnabled |
Abstract base class for segmentation tools.
Implements 2D segmentation specific helper methods, that might be of use to all kind of 2D segmentation tools. At the moment these are:
SegTool2D tries to structure the interaction a bit. If you pass "PressMoveRelease" as the interaction type of your derived tool, you might implement the methods OnMousePressed, OnMouseMoved, and OnMouseReleased. Yes, your guess about when they are called is correct.
$Author$
Definition at line 54 of file mitkSegTool2D.h.
|
protected |
|
protected |
|
overrideprotected |
|
overridevirtual |
Called when the tool gets activated.
Derived tools should call their parents implementation at the beginning of the overriding function.
Reimplemented from mitk::Tool.
|
protected |
Adds a new node called Contourmarker to the datastorage which holds a mitk::PlanarFigure. By selecting this node the slicestack will be reoriented according to the passed PlanarFigure's Geometry.
|
overridevirtual |
Called when the tool gets deactivated.
Derived tools should call their parents implementation at the end of the overriding function.
Reimplemented from mitk::Tool.
|
static |
Calculates for a given Image and PlaneGeometry, which slice of the image (in index corrdinates) is meant by the plane.
image | |
plane | |
affectedDimension | The image dimension, which is constant for all points in the plane, e.g. Axial --> 2 |
affectedSlice | The index of the image slice |
|
overrideprotectedvirtual |
Filters events that cannot be handled by 2D segmentation tools.
Currently an event is discarded if it was not sent by a 2D renderwindow and if it is not of type InteractionPositionEvent
Reimplemented from mitk::EventStateMachine.
|
static |
Extract the slice of an image that the user just scribbles on. The given component denotes the vector component of an vector image.
positionEvent | Event that specifies the plane that should be used to slice |
image | Image that should be sliced |
component | The component to be extracted of a given multi-component image. -1 is the default parameter to denote an invalid component. |
|
static |
Extract the slice of an image cut by given plane. The given component denotes the vector component of a vector image.
planeGeometry | Geometry defining the slice that should be cut out. |
image | Image that should be sliced |
timeStep | TimeStep of the image that shold be sliced |
component | The component to be extracted of a given multi-component image. -1 is the default parameter to denote an invalid component. |
|
static |
|
protected |
Extract the slice of the currently selected reference image that the user just scribbles on.
|
protected |
Overload version that gets the reference slice passed on the passed plane geometry and timestep.
|
protected |
Extract the slice of the currently selected working image that the user just scribbles on.
|
virtual |
|
protectedvirtual |
|
protected |
|
protected |
|
protected |
|
protected |
returns the segmentation node that should be modified by the tool.
|
protected |
|
staticprotected |
Helper function to check if a position events points to a point inside the boundingbox of a passed data instance.
|
virtual |
|
virtual |
|
protectedvirtual |
This function can be reimplemented by derived classes to react on changes of the current time point. Default implementation does nothing.
Reimplemented in mitk::LiveWireTool2D.
void mitk::SegTool2D::SetEnable3DInterpolation | ( | bool | ) |
Enables or disables the 3D interpolation after writing back the 2D segmentation result, and defaults to true.
|
virtual |
void mitk::SegTool2D::SetShowMarkerNodes | ( | bool | ) |
|
static |
Updates the surface interpolation by extracting the contour form the given slice.
slice | the slice from which the contour should be extracted |
workingImage | the segmentation image |
plane | the plane in which the slice lies |
detectIntersection | if true the slice is eroded before contour extraction. If the slice is empty after the erosion it is most likely an intersecting contour an will not be added to the SurfaceInterpolationController |
|
staticprotected |
Updates the surface interpolation by extracting the contour form the given slice.
sliceInfos | vector of slice information instances from which the contours should be extracted |
workingImage | the segmentation image |
detectIntersection | if true the slice is eroded before contour extraction. If the slice is empty after the |
activeLayerID | The layer ID of the active label. |
activeLabelValue | The label value of the active label. erosion it is most likely an intersecting contour an will not be added to the SurfaceInterpolationController |
|
static |
Convenience overloaded version that can be called for a given planeGeometry, slice image and time step. Calls static WriteBackSegmentationResults
|
protected |
Convenience version that can be called for a given event (which is used to deduce timepoint and plane) and a slice image. Calls non static WriteBackSegmentationResults
|
protected |
Convenience version that can be called for a given planeGeometry, slice image and time step. Calls non static WriteBackSegmentationResults
|
staticprotected |
Writes all provided source slices into the data of the passed workingNode. The function does the following: 1) for every passed slice write it to workingNode (and generate and undo/redo step); 2) update the surface interpolation and 3) mark the node as modified.
workingNode | Pointer to the node that contains the working image. |
sliceList | Vector of all slices that should be written into the workingNode. If the list is empty, the function call does nothing. |
writeSliceToVolume | If set to false the write operation (WriteSliceToVolume will be skipped) and only the surface interpolation will be updated. |
|
protected |
Overloaded version that calls the static version and also adds the contour markers.
|
staticprotected |
Writes the provided source slice into the target slice with the given pixel value. If passed workingImage is a LabelSetImage the label set rules will be applied when writing all non zero source pixels into the target slice (e.g. locked lables will not be touched) with the given paintingPixelValue.
targetSlice | Pointer to the slice that should be filled with the content of the sourceSlice. |
sourceSlice | Pointer to the slice that is the source/preview every pixel will be (tried to be) transfered . |
workingImage | Will be used to check if LabeSetImageRules have to be applied and the label set state. |
paintingPixelValue | Value that will be used to paint onto target slice. |
|
static |
Convenience overloaded version that can be called for a given planeGeometry, slice image and time step. For more details see protected WriteSliceToVolume version.
|
staticprotected |
Writes a provided slice into the passed working image. The content of working image that is covered by the slice will be completly overwritten. If asked for it also generates the needed undo/redo steps.
workingImage | Pointer to the image that is the target of the write operation. |
sliceInfo | SliceInfo instance that containes the slice image, the defining plane geometry and time step. |
allowUndo | Indicates if undo/redo operations should be registered for the write operation performed by this call. true: undo/redo will be generated; false: no undo/redo will be generated, so this operation cannot be revoked by the user. |
|
protected |
Definition at line 277 of file mitkSegTool2D.h.
|
protected |
Definition at line 278 of file mitkSegTool2D.h.