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