]> Creatis software - clitk.git/blob - vv/vvToolHistogram.h
Undo commit 10a10f801f12d2cea51dd564a67003971ad66269
[clitk.git] / vv / vvToolHistogram.h
1 /*=========================================================================
2   Program:   vv                     http://www.creatis.insa-lyon.fr/rio/vv
3
4   Authors belong to: 
5   - University of LYON              http://www.universite-lyon.fr/
6   - Léon Bérard cancer center       http://www.centreleonberard.fr
7   - CREATIS CNRS laboratory         http://www.creatis.insa-lyon.fr
8
9   This software is distributed WITHOUT ANY WARRANTY; without even
10   the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
11   PURPOSE.  See the copyright notices for more information.
12
13   It is distributed under dual licence
14
15   - BSD        See included LICENSE.txt file
16   - CeCILL-B   http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
17 ===========================================================================**/
18 #ifndef VVTOOLHISTOGRAM_H
19 #define VVTOOLHISTOGRAM_H
20
21 #include <QtGlobal>
22 #include <QtDesigner/QDesignerExportWidget>
23
24 #include "vvToolBase.h"
25 #include "vvToolWidgetBase.h"
26 #include "ui_vvToolHistogram.h"
27
28 #include "clitkHistogramImage_ggo.h"
29 #include "clitkHistogramImageGenericFilter.h"
30 #include <vtkTable.h>
31 #include <vtkContextView.h>
32 #include <vtkContextScene.h>
33 #include <vtkInteractorObserver.h>
34 #include <vtkEventQtSlotConnect.h>
35
36 //------------------------------------------------------------------------------
37 class vvToolHistogram:
38   public vvToolWidgetBase,
39   public vvToolBase<vvToolHistogram>, 
40   private Ui::vvToolHistogram
41 {
42   Q_OBJECT
43     public:
44   vvToolHistogram(vvMainWindowBase * parent=0, Qt::WindowFlags f=0);
45   ~vvToolHistogram();
46
47   //-----------------------------------------------------
48   static void Initialize();
49   void GetArgsInfoFromGUI();
50   virtual void InputIsSelected(vvSlicerManager * m);
51
52   void computeHistogram();
53   void changeWindowLevel();
54   void computeWindowLevel();
55   void computeMinMax();
56   void SetPoints();
57
58   void displayHistogram();
59
60   QVTKWidget* GetHistogramWidget();
61
62   //-----------------------------------------------------
63   public slots:
64   virtual void apply();
65   virtual bool close();
66   virtual void reject();
67
68   void windowLevelChanged();
69   void reduceWindow();
70   void expandWindow();
71   void translateWindow(double x);
72
73   void SaveAs();
74
75  protected:
76   void RemoveVTKObjects();
77   virtual void closeEvent(QCloseEvent *event);
78   Ui::vvToolHistogram ui;
79   args_info_clitkHistogramImage mArgsInfo;
80
81   double mMinWindowLevel;
82   double mMaxWindowLevel;
83   double originalWindow;
84   double originalLevel;
85   bool mModificationsDone;
86
87   vtkSmartPointer<vtkContextView> mView;
88
89   vtkSmartPointer<vtkTable> mTableWindowLevel;
90   vtkSmartPointer<vtkTable> mTable;
91   //vtkSmartPointer<vtkContextView> mView;
92   clitk::HistogramImageGenericFilter::Pointer mFilter;
93   std::string mTextFileName;
94
95 }; // end class vvToolHistogram
96 //------------------------------------------------------------------------------
97
98 #endif
99