]> Creatis software - creaVtk.git/blob - lib/creaVtk/creaVtkStreamLineScalarSeg.h
#2453 creaVtk Feature New Normal - Stream Lines segmentation by Scalars
[creaVtk.git] / lib / creaVtk / creaVtkStreamLineScalarSeg.h
1 /*
2 # ---------------------------------------------------------------------
3 #
4 # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
5 #                        pour la Sante)
6 # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
7 # Previous Authors : Laurent Guigues, Jean-Pierre Roux
8 # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
9 #
10 #  This software is governed by the CeCILL-B license under French law and
11 #  abiding by the rules of distribution of free software. You can  use,
12 #  modify and/ or redistribute the software under the terms of the CeCILL-B
13 #  license as circulated by CEA, CNRS and INRIA at the following URL
14 #  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
15 #  or in the file LICENSE.txt.
16 #
17 #  As a counterpart to the access to the source code and  rights to copy,
18 #  modify and redistribute granted by the license, users are provided only
19 #  with a limited warranty  and the software's author,  the holder of the
20 #  economic rights,  and the successive licensors  have only  limited
21 #  liability.
22 #
23 #  The fact that you are presently reading this means that you have had
24 #  knowledge of the CeCILL-B license and that you accept its terms.
25 # ------------------------------------------------------------------------
26 */
27
28 #ifndef _CREAVTKSTREAMLINESCALARSEG_H_
29 #define _CREAVTKSTREAMLINESCALARSEG_H_
30
31 #include <string>
32
33 #include <vtkPolyData.h>
34 #include "vtkIdList.h"
35 #include "vtkCellArray.h"
36
37
38 //---------------------------------------------
39 // Class Name: creaVtkStreamLineScalarSeg
40 // [classdescription]
41 //---------------------------------------------
42
43 class creaVtkStreamLineScalarSeg
44 {
45
46 //---------------------------------------------
47 //Methods and attributes exposed to other classes
48 //---------------------------------------------
49 public :
50   creaVtkStreamLineScalarSeg();
51   ~creaVtkStreamLineScalarSeg();
52
53         void SetScalarStreamLinesIn( vtkPolyData* );
54         void SetScalarArrayName( std::string );
55         void SetThresholdLower( double );
56         void SetThresholdUpper( double );
57         void Process();
58         vtkPolyData* GetStreamLinesOut();
59
60
61 //--Method template----------------------------
62 //  void FunctionName(int& parameterA);
63
64
65 //---------------------------------------------
66 //Methods and attributes exposed only to classes
67 //that are derived from this class
68 //---------------------------------------------
69 protected:
70
71 //---------------------------------------------
72 //Methods and attributes only visible by this class
73 //---------------------------------------------
74 private:
75
76         vtkPolyData     *_StreamLinesIn;
77         vtkPolyData     *_StreamLinesOut;
78
79         vtkIdList               *_vtkidlist;
80    vtkPolyData          *_newvtkpolydata;       
81    vtkCellArray *_newvtkcellarray;      
82
83         std::string     _ScalarArrayName;
84         double                  _ThresholdLower;
85         double                  _ThresholdUpper;
86 };
87
88 //-end of _CREAVTKSTREAMLINESCALARSEG_H_------------------------------------------------------
89 #endif