]> Creatis software - creaContours.git/blob - lib/Interface_Icons_NDimensions/interfMainPanel.h
c9267a7a3e7a6f6ab134d1099d5c1c9fa290b82b
[creaContours.git] / lib / Interface_Icons_NDimensions / interfMainPanel.h
1 /*# ---------------------------------------------------------------------
2 #
3 # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
4 #                        pour la Sant�)
5 # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
6 # Previous Authors : Laurent Guigues, Jean-Pierre Roux
7 # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
8 #
9 #  This software is governed by the CeCILL-B license under French law and
10 #  abiding by the rules of distribution of free software. You can  use,
11 #  modify and/ or redistribute the software under the terms of the CeCILL-B
12 #  license as circulated by CEA, CNRS and INRIA at the following URL
13 #  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
14 #  or in the file LICENSE.txt.
15 #
16 #  As a counterpart to the access to the source code and  rights to copy,
17 #  modify and redistribute granted by the license, users are provided only
18 #  with a limited warranty  and the software's author,  the holder of the
19 #  economic rights,  and the successive licensors  have only  limited
20 #  liability.
21 #
22 #  The fact that you are presently reading this means that you have had
23 #  knowledge of the CeCILL-B license and that you accept its terms.
24 # ------------------------------------------------------------------------ */
25
26 #ifndef __interfMainPanel_h_INCLUDED_H__
27 #define __interfMainPanel_h_INCLUDED_H__
28
29 #pragma once
30
31 #include <wx/wx.h>
32 //#include "wxContourEventHandler.h"
33
34 #include "interfNewContourMenu.h"
35 #include "interfIOMenu.h"
36 #include "interfEditMenu.h"
37 #include "interfDeleteMenu.h"
38 #include "interfToolsMenu.h"
39 #include "interfToolsSpreadPanel.h"
40 #include "interfSegmentationMenu.h"
41 #include "interfMenuBar.h"
42 #include "interfToolsPanels.h"
43 #include "interfSegmentationPanels.h"
44 #include "interfImageToolsMenu.h"
45
46 #include <wx/treebook.h>
47 #include <wx/sizer.h>
48 #include <wx/button.h>
49 #include <wx/stattext.h>
50 #include <wx/splitter.h>
51 #include <wx/statline.h>
52
53 #include "vtkImageData.h"
54
55 class interfMainPanel : public wxPanel {
56
57 public:
58
59         interfMainPanel(wxWindow * parent, int sizex, int sizey, wxEvtHandler * evtHandler, std::string datadir = "data/Icons");
60         ~interfMainPanel(void);
61
62         /**     This method should be called the first time by the parent class
63         **      in creates all the panels the first time
64         **/
65         static interfMainPanel* getInstance(wxWindow* parent, std::string datadir, wxEvtHandler * evtHandler=NULL );
66         /**     This method should be called the first time by the parent class
67         **      in creates all the panels the first time
68         **/
69         static interfMainPanel* getInstance(wxWindow* parent, wxEvtHandler * evtHandler=NULL);
70         /**
71         **      Gets the instance of the class
72         **/
73         static interfMainPanel* getInstance();
74         /**
75         **      Ressts the instance of the class
76         **/
77         static void resetInstance();
78
79         /**
80         **      Adds a new checkbox to the scrolledwindow using the checkboxsizer
81         **      @Params id of contour
82         **
83         **/
84         void addContourCheckBox(std::string id);
85
86         /**
87         **      Removes a checkbox from the list of checkboxes in the flexsizer (checkboxsizer)
88         **      @Params id of contour
89         **
90         **/
91         void removeContourCheckBox(std::string id);
92
93
94         /**
95         **      Responds to the events of the buttons, when the same panel is responsible for it. It gets the name
96         **      of the button corresponding to the method that has to be executed,
97         **      it uses attribute eventHandler to call the methods define by the application.
98         **      see setEventHandler(wxEventHandler*)
99         **/
100         void onActionButtonPressed1( wxCommandEvent& event );
101
102         /**
103         **      Shows the panel in the
104         **/
105         void showPanel(wxWindow* panel);
106
107         /**
108         **      Hides the panel in the
109         **/
110         void hidePanel( );
111
112         /**
113         **      Gets the Information panel
114         **/
115         wxPanel* getInfoPanel();
116
117         /**
118         **      This methods connect the event in the class interfNewContourMenu with the world of the appli
119         **/
120         void onCreateContourSpline( );
121         void onCreateContourRectangle( );
122         void onCreateContourCircle( );
123         void onCreateContourLine( );
124         // RaC 09-09 ---------------------
125         void onCreateContourPoints( );
126         // RaC 09-09 ---------------------
127
128         // RaC 10-09 ---------------------
129         void onCreateContourPolygon( );
130         // RaC 10-09 ---------------------
131
132         void onCreateContoursBullEye(wxPanel* panBull);
133         /////////////////////////////////
134         void onDeleteContour();
135         void onDeleteContoursActSlice();
136         void onDeleteAllContours();
137         /////////////////////////
138         void onCopy();
139         void onPaste();
140         void onUndo();
141         void onRedo();
142
143         //////////////////////////
144         void onLoad();
145         void onSave();
146         void onImport();
147         void onTest();
148 /////////////////////////////7
149         void RefreshInterface();
150         vtkImageData* getImageData();
151         void getImageRange(double[2]);
152         void onSegmentationOneSlice(int isovalue,int sampling,int method);
153         void onSegmentationOneSliceITK(wxString distance, wxString sigma, wxString alfa, wxString beta, wxString propagation, wxString iterations, wxString inflation);
154         int GetImageDataSizeZ();
155         void onSegmentationAllSlice(int minZ,int maxZ,int isovalue,int sampling,int method);
156         void onMirrorPressed();
157         void onMirror();
158         void onMirrorAxisShow();
159         void onMirrorAxisHide();
160         void onMirrorChangeWidth(int width);
161         void onThresholdPressed();
162         void onColorLayerImagePressed();
163         void setLabelSegmentationPanelVTK(wxString tmpString);
164         void onSegmentationPressed();
165         void onSegmentationPressedITK();
166         void onRigidPressed();
167         void onWidthOfContour(double width);
168         int getColorWindow();
169         int getWindowLevel();
170         void onBrigthnessColorWindowLevel(int colorwindow,int windowlevel);
171         void onInterpolation(bool interpolate);
172         void onBeforAfterContour(bool before, bool after);
173         void onSpreadPressed();
174         void onConfigurationPressed();
175         void resetAppend();
176         void onSpreadAdd();
177         void onSpreadAddAll();
178         void appendStringSpread(std::string val);
179         void onSpreadGo(int type);
180         void setStringSpread(std::string stringtemp);
181         void onInformationPressed();
182         void getInstantVector(std::vector<int>& tempVector);
183         std::vector<std::string> getOutlinesName(int slide);
184         void onInformationContourLabels(int typeContourGroup,int selection,int minZ,int maxZ,int grayRangeMin,int grayRangeMax);
185         void setStringInfoPanel(wxString tmpString);
186         void setRowLabelInfoPanel(int z, wxString tempString);
187         int getNumberColsInformationPanel();
188         void appendColsInformationPanel(int _numberOfVariablesStatistics);
189         void setCellValueInfoPanel(int z,int tmpIntA,wxString tempString);
190         void setColLableInfoPanel(int tmpIntB ,wxString tmpTitleString);
191         void SetScalarRange(int grayRangeMin,int grayRangeMax);
192         void onSaveResults(std::string directory,std::string namefile, std::string filename,
193                 int typeContourGroup, int selection, int minZ, int maxZ, bool XYZValues, bool contourImage, bool statistics);
194         wxString getCellValue(int j,int i);
195         void onSnakePressed();
196         virtual bool Show(bool show);
197         void ShowResultImages(int typeContourGroup, int selection, int minZ, int maxZ);
198         void SetContourGroup(int contourGroup);
199         void onFlipContours();
200         void FlipContours(int typeContourFlip, int flipDirection);
201
202         
203 //CMRU 29-08-09-----------------------------------------------------------------------------------------------
204
205         /**
206         * Associates the current selected contour with a label
207         */
208         void onPrintLabel();
209
210         /**
211         * Calculates the pixel value in milimeters according to the current contour if the selected contour is a Line Contour
212         * @param size Size in milimeters of the selected contour
213         * @param unit Measurement unit
214         */
215         void onCalibration(wxString size, int unit);
216
217         /**
218         * Calculate the pixel value in milimeters
219         * @param realSize Size of the contour in milimeters
220         * @param sizePixel Size of the contour in pixels
221         */
222         double onePixelSize (double realSize,double sizePixel);
223
224         /**
225         * Returns the value of a pixel in milimeters
226         */
227         double GetPixelValue();
228 //------------------------------------------------------------------------------------------------------------
229
230 private:
231
232
233         static interfMainPanel* interfmainpanel;
234
235
236         static wxFrame* _newframe;
237         wxPanel* menubar;
238         wxPanel* menubar1;
239         wxPanel* menubar2;
240         wxPanel* menubar3;
241         wxPanel* menubar4;
242         wxPanel* menubar5;
243         wxPanel* menubar6;
244
245         wxWindow* currentWindow;
246         wxSplitterWindow* splitterwindow;
247
248         wxPanel* infoPanel;
249         wxPanel* infoPanelMask;
250
251 //CMRU 17-08-09 ------------------------------------------------------------------
252
253         /**
254         * Panel with the calibration options
255         */
256         wxPanel* infoPanelCalibration;
257
258         /**
259         * Panel who contains the calibration panel and the information panel mask
260         */
261         wxPanel* panelAux;
262
263         /**
264         * Value of a pixel in milimeters
265         */
266         double _pixelValue;
267 //--------------------------------------------------------------------------------
268
269         wxStaticText* statictext;
270         wxStaticText* statictext1;
271         wxStaticText* statictext2;
272         wxStaticText* statictext3;
273         wxStaticText* statictext4;
274         wxStaticText* statictext5;
275         wxStaticText* statictext6;
276
277         std::string PANEL;
278         std::string PANEL1;
279         std::string PANEL2;
280         std::string PANEL3;
281         std::string PANEL4;
282         std::string PANEL5;
283         std::string PANEL6;
284
285         wxPanel                         *segmentPanel;
286         wxPanel                         *segmentationPanel;
287         wxPanel                         *segmentPanelITK;
288         wxPanel                         *configPanel;
289         wxPanel                         *spreadPanel;
290         interfSpreadPanel       *panelSpread;
291         wxWindow                        *infoWin;
292         wxPanel                         *informationPanel;
293
294         wxPanel                         *testPanel;
295         interfTestPanel         *panelTest;
296
297         wxPanel                         *flipPanel;
298         interfFlipPanel         *panelFlip;
299         
300         wxPanel                         *mirrorPanel;
301         interfMirrorPanel       *panelMirror;
302
303         wxPanel                         *thresholdPanel;
304         wxPanel                         *colorImageLayerPanel;
305
306         bool axisshown;
307         bool refLineShown;
308
309         //This attribute contains the panel in charge of adding and removing the corresponding checkboxes in
310         //list of contours
311         interfToolsSpreadPanel* toolspread;
312
313         /**
314         **      This method initializes the tools panel, with the bar and the panel where the contours can be added
315         **      and removed.
316         **      @params size of the buttons panel
317         **      @params sizey of the buttons panel
318         **      @params evtHandler this is the class in charge of responding to the events of the buttons
319         **/
320         wxPanel* initializeToolsPanel(wxWindow* parent, int sizex, int sizey, wxEvtHandler * evtHandler);
321
322         /**
323         **      initialize a statictext component of the interface
324         **/
325         wxStaticText* getText(wxWindow* parent, std::string nom);
326         /**
327         ** initializes a button with data
328         **/
329         wxButton* getButton(wxWindow* parent);
330         /**
331         ** Puts the panel button and the text int the sizer
332         **/
333         wxPanel* setMenuTextSizer(wxWindow* parent, wxPanel* panel, wxStaticText* text);
334
335
336 };
337
338 #endif
339