]> Creatis software - creaMaracasVisu.git/blob - lib/maracasVisuLib/src/kernel/include/marContourVO.h
Support #1768 CREATIS Licence insertion
[creaMaracasVisu.git] / lib / maracasVisuLib / src / kernel / include / marContourVO.h
1 /*# ---------------------------------------------------------------------
2 #
3 # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
4 #                        pour la Sant�)
5 # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
6 # Previous Authors : Laurent Guigues, Jean-Pierre Roux
7 # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
8 #
9 #  This software is governed by the CeCILL-B license under French law and
10 #  abiding by the rules of distribution of free software. You can  use,
11 #  modify and/ or redistribute the software under the terms of the CeCILL-B
12 #  license as circulated by CEA, CNRS and INRIA at the following URL
13 #  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
14 #  or in the file LICENSE.txt.
15 #
16 #  As a counterpart to the access to the source code and  rights to copy,
17 #  modify and redistribute granted by the license, users are provided only
18 #  with a limited warranty  and the software's author,  the holder of the
19 #  economic rights,  and the successive licensors  have only  limited
20 #  liability.
21 #
22 #  The fact that you are presently reading this means that you have had
23 #  knowledge of the CeCILL-B license and that you accept its terms.
24 # ------------------------------------------------------------------------ */
25
26 /*=========================================================================
27
28   Program:   wxMaracas
29   Module:    $RCSfile: marContourVO.h,v $
30   Language:  C++
31   Date:      $Date: 2012/11/15 14:15:31 $
32   Version:   $Revision: 1.2 $
33
34   Copyright: (c) 2002, 2003
35   License:
36   
37      This software is distributed WITHOUT ANY WARRANTY; without even 
38      the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 
39      PURPOSE.  See the above copyright notice for more information.
40
41 =========================================================================*/
42 #ifndef __MAR__KERNEL__CONTOURVO__HXX__
43 #define __MAR__KERNEL__CONTOURVO__HXX__
44
45 #include "marContour.h"
46 #include <vtkPolyData.h>
47 #include <vtkProbeFilter.h>
48 #include <vtkContourFilter.h>
49 #include <vtkCleanPolyData.h>
50 #include <vtkPolyDataConnectivityFilter.h>
51 #include <vtkStripper.h>
52
53 class vtkPoints;
54 class vtkCellArray;
55
56
57 class MAR_KERNEL_EXPORT  marContourVO 
58 {
59
60    public:
61
62            
63            marContour* getContour( );
64            void setContour(marContour* cont);
65
66            vtkPoints* get3DContour( );
67            void set3DContour(vtkPoints* cont);
68
69            vtkPolyData* get2DContour( );
70            void set2DContour(vtkPolyData* cont);
71
72            vtkPoints* get2DDiameterMin( );
73            void set2DDiameterMin(vtkPoints* diam);
74
75            vtkPoints* get2DDiameterMax( );
76            void set2DDiameterMax(vtkPoints* diam);
77
78            double getSignal( );
79            void setSignal(double cont);
80
81            int getType( );
82            void setType(int cont);
83
84            vtkContourFilter* getIsocontour();
85            void setIsocontour(vtkContourFilter* iso);
86
87            vtkCleanPolyData* getIsocontourCpd();
88            void setIsocontourCpd(vtkCleanPolyData* isocpd);
89
90            vtkCleanPolyData* getIsocontourCpd2();
91            void setIsocontourCpd2(vtkCleanPolyData* isocpd);
92
93            vtkPolyDataConnectivityFilter* getIsocontourDcf();
94            void setIsocontourDcf(vtkPolyDataConnectivityFilter* isodcf);
95
96            vtkStripper* getIsocontourStripped();
97            void setIsocontourStripped(vtkStripper* isoStripped);
98
99            bool isReplaced();
100            void setReplaced(bool rep);
101
102            ~marContourVO();
103                 marContourVO();
104
105    private:
106
107             
108         marContour*             _contours;                                      //  DATA-MODEL-2D                       Axis Contours
109         vtkPoints*                      _3Dcontour;                                     //  VISUALISATION_VTK 3D        Axis perpendicular Contour
110         vtkPolyData*            _2Dcontours;                            //  VISUALISATION_VTK 2D        Axis perpendicular Contour
111         vtkPoints*                      _2DDiameterMin;                         //  VISUALISATION_VTK 2D        Line diameter Minimum
112         vtkPoints*                      _2DDiameterMax;                         //  VISUALISATION_VTK 2D        Line diameter Maximum
113         double                          _signal;                                        //  Axis intensity signal
114         int                                     _contType;                                      //  ContourType
115         vtkContourFilter*       _isocontour;
116         vtkCleanPolyData*       _isocontour_cpd;
117         vtkPolyDataConnectivityFilter*  _isocontour_dcf;
118         vtkCleanPolyData*       _isocontour_cpd2;
119         vtkStripper*            _isocontour_stripped;
120         bool                            _replaced;
121
122  
123 }; 
124 #endif // __MAR__KERNEL__CONTOUR_VO__HXX__
125