]> Creatis software - creaVtk.git/blob - lib/creaVtk/creaVtkPlaneWidget.h
#3477 Set Normal in PlaneWidget
[creaVtk.git] / lib / creaVtk / creaVtkPlaneWidget.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 _CREAVTKPLANEWIDGET_H_
29 #define _CREAVTKPLANEWIDGET_H_
30
31 //---------------------------------------------
32 // Class Name: PlaneWidget
33 // [classdescription]
34 //---------------------------------------------
35
36 #include "vtkCommand.h"
37 #include "vtkImageData.h"
38 #include "vtkPlaneSource.h"
39 #include "vtkPlaneWidget.h"
40 #include "vtkRenderer.h"
41
42
43 class creaVtkPlaneWidget;
44
45 //---------------------------------------------
46 class creaVtkCallbackPlaneWidget : public vtkCommand
47 {
48         public:
49                 creaVtkPlaneWidget *creavtkplanewidget;
50                         
51                 static creaVtkCallbackPlaneWidget *New() { return new creaVtkCallbackPlaneWidget; }
52                 void Delete() { delete this; }
53                 virtual void Execute(vtkObject *caller, unsigned long, void*);
54                 creaVtkCallbackPlaneWidget():creavtkplanewidget(NULL) { }                       
55 };
56
57
58 //---------------------------------------------
59 //---------------------------------------------
60 //---------------------------------------------
61
62 class creaVtkPlaneWidget
63 {
64
65 //---------------------------------------------
66 //Methods and attributes exposed to other classes
67 //---------------------------------------------
68 public :
69     creaVtkPlaneWidget();
70     ~creaVtkPlaneWidget();
71
72     void                        SetImage(vtkImageData* image);
73     vtkImageData*       GetImage();
74     void                        SetActive(bool active);
75     bool                        GetActive();
76     void                        SetRenderer(vtkRenderer* renderer);
77     vtkRenderer*            GetRenderer();
78     vtkPlaneSource*     GetPlaneSource();
79     void                        SetResolution(int resolution);
80     int                         GetResolution();
81     void                        SetRepresentation(int represtation);
82     int                         GetRepresentation();
83     std::vector<double> GetCenter();
84     std::vector<double> GetNormal();
85
86     void                SetOrigin( std::vector<double> origin);
87     void                SetNormalIn( std::vector<double> normalin);
88
89     void                        Process();
90     void                        UpdatePlane();
91     virtual void            Execute();
92
93
94 //---------------------------------------------
95 //Methods and attributes exposed only to classes
96 //that are derived from this class
97 //---------------------------------------------
98 protected:
99
100 //---------------------------------------------
101 //Methods and attributes only visible by this class
102 //---------------------------------------------
103 private:
104         bool                            _firsttime;
105         bool                            _active;
106         vtkImageData*           _image;
107         vtkRenderer     *               _renderer;
108         int                             _resolution;
109         int                             _representation;
110     std::vector<double> _origin;
111         std::vector<double> _normalin;
112
113         vtkPlaneWidget      *_vPlaneWidget;
114     vtkPlaneSource      *_vPlaneSource;
115 };
116
117 //-end of _CREAVTKPLANEWIDGET_H_------------------------------------------------------
118 #endif