Computer Assited Medical Intervention Tool Kit  version 4.1
ConnectedComponents.h
Go to the documentation of this file.
1 /*****************************************************************************
2  * $CAMITK_LICENCE_BEGIN$
3  *
4  * CamiTK - Computer Assisted Medical Intervention ToolKit
5  * (c) 2001-2018 Univ. Grenoble Alpes, CNRS, TIMC-IMAG UMR 5525 (GMCAO)
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 CONNECTEDCOMPONENTS_H
26 #define CONNECTEDCOMPONENTS_H
27 
28 #include <QObject>
29 #include <Action.h>
30 #include <ImageComponent.h>
31 #include <ActionWidget.h>
32 
33 #include "ITKFilterAPI.h"
34 
44  Q_OBJECT
45 
46  // declaration of parameters
47  Q_PROPERTY(int nbConnectedComponents READ getNbConnectedComponents)
48 
49 
50 public:
53 
55  virtual ~ConnectedComponents() = default;
56 
57 public slots:
63  virtual ApplyStatus apply();
64 
65  int getNbConnectedComponents() const ;
66  void setNbConnectedComponents(const int nbConnectedComponents);
67 
68 private:
70  virtual void process(camitk::ImageComponent*);
71 
72  vtkSmartPointer<vtkImageData> implementProcess(vtkSmartPointer<vtkImageData> img);
73 
74  template <class InputPixelType, class OutputPixelType, const int dim>
75  vtkSmartPointer<vtkImageData> itkProcess(vtkSmartPointer<vtkImageData> img);
76 
77  int nbConnectedComponents;
78 
79 
80 };
81 #endif // CONNECTEDCOMPONENTS_H
ConnectedComponents::process
virtual void process(camitk::ImageComponent *)
helper method to simplify the target component processing
Definition: ConnectedComponents.cpp:75
ConnectedComponents::ConnectedComponents
ConnectedComponents(camitk::ActionExtension *)
Default Constructor.
Definition: ConnectedComponents.cpp:42
camitk::Action::setFamily
void setFamily(QString family)
the name of the family in which this action is associated
Definition: Action.cpp:129
camitk::Action::SUCCESS
@ SUCCESS
everything went according to plan
Definition: Action.h:247
ITKFilterAPI.h
camitk::Action::ApplyStatus
ApplyStatus
Definition: Action.h:246
camitk::Action::setName
void setName(QString name)
Definition: Action.cpp:113
ConnectedComponents.h
camitk::Action::setComponent
void setComponent(QString component)
the name of the component class that can be used by this action
Definition: Action.cpp:124
ConnectedComponents::getNbConnectedComponents
int getNbConnectedComponents() const
Definition: ConnectedComponents.cpp:56
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:73
camitk::Action::getTargets
const ComponentList getTargets() const
the currently selected and valid (regarding the component property) components, for which this action...
Definition: Action.cpp:159
Action.h
itkImageToVTKImageFilter.h
ConnectedComponents::itkProcess
vtkSmartPointer< vtkImageData > itkProcess(vtkSmartPointer< vtkImageData > img)
Definition: ConnectedComponents.cpp:91
ActionWidget.h
camitk::Action::addTag
void addTag(QString tag)
add a tag to the tags list of this action
Definition: Action.cpp:134
camitk::Action
Action class is an abstract class that enables you to build a action (generally on a component)....
Definition: Action.h:230
ConnectedComponents::setNbConnectedComponents
void setNbConnectedComponents(const int nbConnectedComponents)
Definition: ConnectedComponents.cpp:61
camitk::Action::apply
virtual ApplyStatus apply()=0
This method is called when the action has to be applied on the target list (get the target lists usin...
ConnectedComponents::nbConnectedComponents
int nbConnectedComponents
Definition: ConnectedComponents.h:70
ConnectedComponents::apply
virtual ApplyStatus apply()
this method is automatically called when the action is triggered.
Definition: ConnectedComponents.cpp:67
camitk::Action::setDescription
void setDescription(QString description)
the description of the action
Definition: Action.cpp:119
camitk::Component::getName
QString getName() const override
get the name to be displayed
Definition: sdk/libraries/core/component/Component.h:849
itk::ImageToVTKImageFilter
Converts an ITK image into a VTK image and plugs a itk data pipeline to a VTK datapipeline.
Definition: itkImageToVTKImageFilter.h:81
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:82
camitk::ImageComponent::getImageData
vtkSmartPointer< vtkImageData > getImageData() const
get the image volume managed by this Component
Definition: ImageComponent.h:104
ConnectedComponents
Perform a connected component analysis on the ImageComponent.
Definition: ConnectedComponents.h:43
ConnectedComponents::implementProcess
vtkSmartPointer< vtkImageData > implementProcess(vtkSmartPointer< vtkImageData > img)
itkVTKImageToImageFilter.h
camitk::refresh
void refresh()
refresh the display
itk::VTKImageToImageFilter
Converts a VTK image into an ITK image and plugs a vtk data pipeline to an ITK datapipeline.
Definition: itkVTKImageToImageFilter.h:58
ItkProgressObserver.h
ImageComponent.h
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:298
Application.h
camitk
Definition: Action.cpp:36