]> Creatis software - clitk.git/blob - vv/vvToolHistogram.h
437e4e6e04ef5ba9bf7ea7ef6fef5cf941e9a82b
[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 #if QT_VERSION >= 0x050000
23 #include <QtUiPlugin/QDesignerExportWidget>
24 #else
25 #include <QtDesigner/QDesignerExportWidget>
26 #endif
27
28 #include "vvToolBase.h"
29 #include "vvToolWidgetBase.h"
30 #include "ui_vvToolHistogram.h"
31
32 #include "clitkHistogramImage_ggo.h"
33 #include "clitkHistogramImageGenericFilter.h"
34 #include <vtkTable.h>
35 #include <vtkContextView.h>
36 #include <vtkContextScene.h>
37 #include <vtkInteractorObserver.h>
38 #include <vtkEventQtSlotConnect.h>
39
40 //------------------------------------------------------------------------------
41 class vvToolHistogram:
42   public vvToolWidgetBase,
43   public vvToolBase<vvToolHistogram>, 
44   private Ui::vvToolHistogram
45 {
46   Q_OBJECT
47     public:
48   vvToolHistogram(vvMainWindowBase * parent=0, Qt::WindowFlags f=0);
49   ~vvToolHistogram();
50
51   //-----------------------------------------------------
52   static void Initialize();
53   void GetArgsInfoFromGUI();
54   virtual void InputIsSelected(vvSlicerManager * m);
55
56   void computeHistogram();
57   void changeWindowLevel();
58   void computeWindowLevel();
59   void computeMinMax();
60   void SetPoints();
61
62   void displayHistogram();
63
64   QVTKWidget* GetHistogramWidget();
65
66   //-----------------------------------------------------
67   public slots:
68   virtual void apply();
69   virtual bool close();
70   virtual void reject();
71
72   void windowLevelChanged();
73   void reduceWindow();
74   void expandWindow();
75   void translateWindow(double x);
76
77   void SaveAs();
78
79  protected:
80   void RemoveVTKObjects();
81   virtual void closeEvent(QCloseEvent *event);
82   Ui::vvToolHistogram ui;
83   args_info_clitkHistogramImage mArgsInfo;
84
85   double mMinWindowLevel;
86   double mMaxWindowLevel;
87   double originalWindow;
88   double originalLevel;
89   bool mModificationsDone;
90
91   vtkSmartPointer<vtkContextView> mView;
92
93   vtkSmartPointer<vtkTable> mTableWindowLevel;
94   vtkSmartPointer<vtkTable> mTable;
95   //vtkSmartPointer<vtkContextView> mView;
96   clitk::HistogramImageGenericFilter::Pointer mFilter;
97   std::string mTextFileName;
98
99 }; // end class vvToolHistogram
100 //------------------------------------------------------------------------------
101
102 #endif
103