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