]> Creatis software - clitk.git/blob - vv/vvToolROIManager.h
Ensure compatibility between Qt5.5 and Qt5.x or less
[clitk.git] / vv / vvToolROIManager.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
19 #ifndef VVTOOLROIMANAGER_H
20 #define VVTOOLROIMANAGER_H
21
22 #include <QtGlobal>
23 #if QT_VERSION < QT_VERSION_CHECK(5, 5, 0)
24 #include <QtDesigner/QDesignerExportWidget>
25 #else
26 #include <QtUiPlugin/QDesignerExportWidget>
27 #endif
28 #include <QSharedPointer>
29
30 #include "vvToolBase.h"
31 #include "vvROIActor.h"
32 #include "clitkDicomRT_ROI.h"
33 #include "ui_vvToolROIManager.h"
34
35 class vvROIActor;
36
37 //------------------------------------------------------------------------------
38 class vvToolROIManager:
39   public QWidget, 
40   public vvToolBase<vvToolROIManager>, 
41   public Ui::vvToolROIManager
42 {
43   Q_OBJECT
44   public:
45   vvToolROIManager(vvMainWindowBase* parent=0, Qt::WindowFlags f=Qt::Dialog);
46   virtual ~vvToolROIManager();
47
48   static void Initialize();
49   virtual void InputIsSelected(vvSlicerManager *m);
50
51   void AddImage(vvImage * binaryImage, std::string name, std::string filename, double BG, bool m_modeBG=true);
52   void UpdateAllContours();
53   void UpdateAllROIStatus();
54   virtual void SaveState(std::auto_ptr<QXmlStreamWriter> & m_XmlWriter);
55   virtual void InitializeNewTool(bool ReadStateFlag);
56
57   public slots:
58   void AnImageIsBeingClosed(vvSlicerManager *);
59   void SelectedImageHasChanged(vvSlicerManager *);
60   void Open();
61   void OpenBinaryImage(QStringList & filenames);
62   void OpenDicomImage(std::string filaneme);
63   void SelectedItemChangedInTree();
64   void VisibleROIToggled(bool b);
65   void VisibleContourROIToggled(bool b);
66   void OpacityChanged(int v);
67   void ChangeColor();
68   void ChangeContourColor();
69   void ChangeContourWidth(int n);
70   void ChangeDepth(int n);
71   void AllVisibleROIToggled(int b);
72   void AllVisibleContourROIToggled(int b);
73   void ReloadCurrentROI();  
74   void close();
75   void RemoveROI();
76   vvSlicerManager * GetCurrentSlicerManager() { return mCurrentSlicerManager; }
77
78 protected:
79   Ui::vvToolROIManager ui;
80   vvSlicerManager * mCurrentSlicerManager; // need it because do not inherit from vvToolWidgetBase
81   vvImage * mCurrentImage;
82   vvMainWindowBase * mMainWindow;
83   int mIndexFirstTab;
84   bool mOpenFileBrowserFlag;
85   
86   int mNumberOfVisibleROI;
87   int mNumberOfVisibleContourROI;
88   static int nbTotalROI;
89
90   vtkSmartPointer<vtkLookupTable> mDefaultLUTColor;
91
92   QStringList mOpenedBinaryImageFilenames;
93   std::vector<clitk::DicomRT_ROI::Pointer> mROIList;
94   std::vector<QSharedPointer<vvROIActor> > mROIActorsList;
95
96   // Data for the widget Tree
97   std::vector< QSharedPointer<QTreeWidgetItem> > mTreeWidgetList;
98   std::map<clitk::DicomRT_ROI::Pointer, QTreeWidgetItem *> mMapROIToTreeWidget;
99   std::map<QTreeWidgetItem *, clitk::DicomRT_ROI::Pointer> mMapTreeWidgetToROI;
100   
101   // Data for current selected roi
102   clitk::DicomRT_ROI::Pointer mCurrentROI;
103   QSharedPointer<vvROIActor> mCurrentROIActor;
104   
105   // Data for XML Reader
106   void ReadXMLInformation();
107   void ReadXMLInformation_ROI();
108   uint mInitialImageIndex;
109   QStringList mROIFilenames;
110   std::vector<QSharedPointer<vvROIActor> > mROIActorsParamList;
111  
112 }; // end class vvToolROIManager
113 //------------------------------------------------------------------------------
114
115 #endif
116