Computer Assited Medical Intervention Tool Kit  version 5.0
MorphologicalOperators.h
Go to the documentation of this file.
1 /*****************************************************************************
2  * $CAMITK_LICENCE_BEGIN$
3  *
4  * CamiTK - Computer Assisted Medical Intervention ToolKit
5  * (c) 2001-2021 Univ. Grenoble Alpes, CNRS, Grenoble INP, TIMC, 38000 Grenoble, France
6  *
7  * Visit http://camitk.imag.fr for more information
8  *
9  * This file is part of CamiTK.
10  *
11  * CamiTK is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License version 3
13  * only, as published by the Free Software Foundation.
14  *
15  * CamiTK is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU Lesser General Public License version 3 for more details.
19  *
20  * You should have received a copy of the GNU Lesser General Public License
21  * version 3 along with CamiTK. If not, see <http://www.gnu.org/licenses/>.
22  *
23  * $CAMITK_LICENCE_END$
24  ****************************************************************************/
25 #ifndef MORPHOLOGICALOPERATORS_H
26 #define MORPHOLOGICALOPERATORS_H
27 
28 #include <QObject>
29 #include <Action.h>
30 #include <ImageComponent.h>
31 #include <ActionWidget.h>
32 
33 #include "ITKFilterAPI.h"
34 
35 #include <itkImage.h>
36 
46  Q_OBJECT
47 
48 public:
50  enum MorphoType {GREY_LEVEL, BINARY};
51 
52  Q_ENUM(MorphoType)
53 
54 
55  enum MorphoOperation {EROSION, DILATION, OPENING, CLOSING};
56 
57  Q_ENUM(MorphoOperation)
58 
59 
61 
63  MorphoType getMorphoType() const ;
64 
66  MorphoOperation getMorphoOperation() const ;
67 
69  virtual ~MorphologicalOperators();
70 
71 public slots:
78 
79 private:
81  virtual void process(camitk::ImageComponent*);
82 
83 private:
84  vtkSmartPointer<vtkImageData> implementProcess(vtkSmartPointer<vtkImageData> img);
85 
86  template <class InputPixelType, class OutputPixelType, const int dim>
87  vtkSmartPointer<vtkImageData> itkProcess(vtkSmartPointer<vtkImageData> img);
88 
89  template <class InputPixelType, class OutputPixelType, const int dim>
90  vtkSmartPointer<vtkImageData> binaryErosionFilter(vtkSmartPointer<vtkImageData> img);
91  template <class InputPixelType, class OutputPixelType, const int dim>
92  vtkSmartPointer<vtkImageData> binaryDilationFilter(vtkSmartPointer<vtkImageData> img);
93  template <class InputPixelType, class OutputPixelType, const int dim>
94  vtkSmartPointer<vtkImageData> binaryOpeningFilter(vtkSmartPointer<vtkImageData> img);
95  template <class InputPixelType, class OutputPixelType, const int dim>
96  vtkSmartPointer<vtkImageData> binaryClosureFilter(vtkSmartPointer<vtkImageData> img);
97 
98  template <class InputPixelType, class OutputPixelType, const int dim>
99  vtkSmartPointer<vtkImageData> greyLevelErosionFilter(vtkSmartPointer<vtkImageData> img);
100  template <class InputPixelType, class OutputPixelType, const int dim>
101  vtkSmartPointer<vtkImageData> greyLevelDilationFilter(vtkSmartPointer<vtkImageData> img);
102  template <class InputPixelType, class OutputPixelType, const int dim>
103  vtkSmartPointer<vtkImageData> greyLevelOpeningFilter(vtkSmartPointer<vtkImageData> img);
104  template <class InputPixelType, class OutputPixelType, const int dim>
105  vtkSmartPointer<vtkImageData> greyLevelClosureFilter(vtkSmartPointer<vtkImageData> img);
106 
107 
108 
109 protected:
111  MorphoType typeOfOperation;
112  MorphoOperation operation;
113  int structuringElementSize;
114 
115  QString suffix;
116 
117 };
118 
119 #endif // MORPHOLOGICALOPERATORS_H
MorphologicalOperators::getMorphoType
MorphoType getMorphoType() const
Get the morphological type of operation.
Definition: MorphologicalOperators.cpp:79
camitk::Action::setFamily
void setFamily(QString family)
the name of the family in which this action is associated
Definition: Action.cpp:136
MorphologicalOperators::apply
virtual camitk::Action::ApplyStatus apply()
this method is automatically called when the action is triggered.
Definition: MorphologicalOperators.cpp:88
MorphologicalOperators::binaryErosionFilter
vtkSmartPointer< vtkImageData > binaryErosionFilter(vtkSmartPointer< vtkImageData > img)
Definition: MorphologicalOperators.cpp:179
MorphologicalOperators::~MorphologicalOperators
virtual ~MorphologicalOperators()
Default Destructor.
Definition: MorphologicalOperators.cpp:75
camitk::Action::SUCCESS
@ SUCCESS
everything went according to plan
Definition: Action.h:248
MorphologicalOperators::greyLevelDilationFilter
vtkSmartPointer< vtkImageData > greyLevelDilationFilter(vtkSmartPointer< vtkImageData > img)
Definition: MorphologicalOperators.cpp:538
ITKFilterAPI.h
MorphologicalOperators::structuringElementSize
int structuringElementSize
Definition: MorphologicalOperators.h:136
camitk::Property::setEnumTypeName
void setEnumTypeName(QString)
if the property's type is an enum, set the name of the registered Qt Enum.
Definition: Property.cpp:108
MorphologicalOperators::MorphologicalOperators
MorphologicalOperators(camitk::ActionExtension *)
Default Constructor.
Definition: MorphologicalOperators.cpp:44
camitk::Action::ApplyStatus
ApplyStatus
Definition: Action.h:247
camitk::Action::setName
void setName(QString name)
Definition: Action.cpp:120
MorphologicalOperators::getMorphoOperation
MorphoOperation getMorphoOperation() const
Get the morphological operation selected.
Definition: MorphologicalOperators.cpp:83
camitk::Action::setComponent
void setComponent(QString component)
the name of the component class that can be used by this action
Definition: Action.cpp:131
camitk::ItkProgressObserver::Pointer
itk::SmartPointer< Self > Pointer
Definition: ItkProgressObserver.h:96
camitk::ImageComponent
The manager of the Image Volume data. An image volume data has no concrete 3D representation,...
Definition: ImageComponent.h:77
camitk::Action::getTargets
const ComponentList getTargets() const
the currently selected and valid (regarding the component property) components, for which this action...
Definition: Action.cpp:166
Action.h
MorphologicalOperators::BINARY
@ BINARY
Definition: MorphologicalOperators.h:96
MorphologicalOperators::OPENING
@ OPENING
Definition: MorphologicalOperators.h:78
itkImageToVTKImageFilter.h
camitk::Property
This class describes a property that can be used in components and actions or any class that needs to...
Definition: Property.h:303
ActionWidget.h
camitk::Action::addTag
void addTag(QString tag)
add a tag to the tags list of this action
Definition: Action.cpp:141
MorphologicalOperators::greyLevelClosureFilter
vtkSmartPointer< vtkImageData > greyLevelClosureFilter(vtkSmartPointer< vtkImageData > img)
Definition: MorphologicalOperators.cpp:602
MorphologicalOperators::MorphoType
MorphoType
Define the possible types of morphological operations.
Definition: MorphologicalOperators.h:73
MorphologicalOperators::process
virtual void process(camitk::ImageComponent *)
helper method to simplify the target component processing
Definition: MorphologicalOperators.cpp:96
camitk::Action
Action class is an abstract class that enables you to build a action (generally on a component)....
Definition: Action.h:231
Property.h
camitk::Property::setAttribute
void setAttribute(const QString &attribute, const QVariant &value)
Set a given property for this attribute.
Definition: Property.cpp:183
camitk::Action::apply
virtual camitk::Action::ApplyStatus apply()=0
This method is called when the action has to be applied on the target list (get the target lists usin...
MorphologicalOperators::DILATION
@ DILATION
Definition: MorphologicalOperators.h:78
camitk::Action::setDescription
void setDescription(QString description)
the description of the action
Definition: Action.cpp:126
camitk::Component::getName
QString getName() const override
get the name to be displayed
Definition: sdk/libraries/core/component/Component.h:907
MorphologicalOperators::binaryDilationFilter
vtkSmartPointer< vtkImageData > binaryDilationFilter(vtkSmartPointer< vtkImageData > img)
Definition: MorphologicalOperators.cpp:246
itk::ImageToVTKImageFilter
Converts an ITK image into a VTK image and plugs a itk data pipeline to a VTK datapipeline.
Definition: itkImageToVTKImageFilter.h:81
MorphologicalOperators::greyLevelErosionFilter
vtkSmartPointer< vtkImageData > greyLevelErosionFilter(vtkSmartPointer< vtkImageData > img)
Definition: MorphologicalOperators.cpp:472
MorphologicalOperators::CLOSING
@ CLOSING
Definition: MorphologicalOperators.h:78
MorphologicalOperators::implementProcess
vtkSmartPointer< vtkImageData > implementProcess(vtkSmartPointer< vtkImageData > img)
camitk::Action::addParameter
virtual bool addParameter(Property *)
Add a new parameter to the action, using the CamiTK property class.
Definition: Action.cpp:440
MorphologicalOperators::binaryClosureFilter
vtkSmartPointer< vtkImageData > binaryClosureFilter(vtkSmartPointer< vtkImageData > img)
Definition: MorphologicalOperators.cpp:311
ITKFILTER_API
#define ITKFILTER_API
Definition: ITKFilterAPI.h:8
camitk::ActionExtension
This class describes what is a generic Action extension. To add a ActionExtension to CamiTK core,...
Definition: ActionExtension.h:80
MorphologicalOperators::EROSION
@ EROSION
Definition: MorphologicalOperators.h:78
camitk::ImageComponent::getImageData
vtkSmartPointer< vtkImageData > getImageData() const override
get the image volume managed by this Component
Definition: ImageComponent.h:123
itkVTKImageToImageFilter.h
camitk::refresh
void refresh()
refresh the display
MorphologicalOperators::suffix
QString suffix
Definition: MorphologicalOperators.h:138
MorphologicalOperators::GREY_LEVEL
@ GREY_LEVEL
Definition: MorphologicalOperators.h:96
itk::VTKImageToImageFilter
Converts a VTK image into an ITK image and plugs a vtk data pipeline to an ITK datapipeline.
Definition: itkVTKImageToImageFilter.h:58
MorphologicalOperators::binaryOpeningFilter
vtkSmartPointer< vtkImageData > binaryOpeningFilter(vtkSmartPointer< vtkImageData > img)
Definition: MorphologicalOperators.cpp:390
ItkProgressObserver.h
MorphologicalOperators
Perform some morphological operators such as opening, closing ...
Definition: MorphologicalOperators.h:45
MorphologicalOperators.h
MorphologicalOperators::itkProcess
vtkSmartPointer< vtkImageData > itkProcess(vtkSmartPointer< vtkImageData > img)
Definition: MorphologicalOperators.cpp:117
ImageComponent.h
MorphologicalOperators::greyLevelOpeningFilter
vtkSmartPointer< vtkImageData > greyLevelOpeningFilter(vtkSmartPointer< vtkImageData > img)
Definition: MorphologicalOperators.cpp:679
camitk::Component
A Component represents something that could be included in the explorer view, the interactive 3D view...
Definition: sdk/libraries/core/component/Component.h:302
Application.h
camitk
Definition: Action.cpp:35
MorphologicalOperators::MorphoOperation
MorphoOperation
Define the possible morphological operations.
Definition: MorphologicalOperators.h:78