]> Creatis software - creaContours.git/blob - lib/Interface_Icons_NDimensions/interfToolsPanels.cxx
5aa8b3fccf31e8d2276cf2f4b193f049a95d2e60
[creaContours.git] / lib / Interface_Icons_NDimensions / interfToolsPanels.cxx
1 #include "interfToolsPanels.h"
2 #include "interfMainPanel.h"
3
4 interfConfigurationPanel::interfConfigurationPanel(wxWindow * parent)
5 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN)
6 {
7 //      wxPanel *panel                                                  = new wxPanel(parent,-1,wxDefaultPosition, wxDefaultSize,wxNO_BORDER, wxString(_T("")));
8         _withOfContourLine                                              = new wxSlider(this, -1, 1 , 1, 10, wxDefaultPosition, wxDefaultSize, wxSL_HORIZONTAL|wxSL_LABELS, wxDefaultValidator);
9
10         double range[2];
11         interfMainPanel::getInstance()->GetImageDataRange(range);
12         //this->_theViewPanel->getSceneManager()->GetImageDataRange(range);
13
14         //wxVtk2DBaseView *wxvtk2dbaseview = (wxVtk2DBaseView*)this->_theViewPanel->getWxVtkBaseView();
15         //vtkImageViewer2 *imageviewer = wxvtk2dbaseview->_imageViewer2XYZ->GetVtkImageViewer2();
16         //int colorwindow = (int)imageviewer->GetWindowLevel()->GetLevel();
17         //int windowlevel = (int)imageviewer->GetWindowLevel()->GetWindow();    
18
19         int colorwindow = interfMainPanel::getInstance()->getColorWindow();
20         int windowlevel = interfMainPanel::getInstance()->getWindowLevel();
21
22         
23         _brithtnessWindowLevel                                  = new wxSlider(this, -1, windowlevel , 1, range[1], wxDefaultPosition, wxDefaultSize, wxSL_HORIZONTAL|wxSL_LABELS, wxDefaultValidator);
24         _brithtnessColorLevel                                   = new wxSlider(this, -1, colorwindow , 1, range[1], wxDefaultPosition, wxDefaultSize, wxSL_HORIZONTAL|wxSL_LABELS, wxDefaultValidator);
25
26         _interpolationCheckBox = new wxCheckBox(this, -1, _T("Image interpolation") );
27         _interpolationCheckBox->SetValue(true);         
28
29         Connect( _withOfContourLine->GetId()            ,       wxEVT_SCROLL_CHANGED    , (wxObjectEventFunction) &interfConfigurationPanel::onWidthOfContour   ); 
30         Connect( _withOfContourLine->GetId()            ,       wxEVT_SCROLL_THUMBTRACK , (wxObjectEventFunction) &interfConfigurationPanel::onWidthOfContour   ); 
31
32         Connect( _brithtnessWindowLevel->GetId()        ,       wxEVT_SCROLL_CHANGED    , (wxObjectEventFunction) &interfConfigurationPanel::onBrigthnessColorWindowLevel       ); 
33         Connect( _brithtnessWindowLevel->GetId()        ,       wxEVT_SCROLL_THUMBTRACK , (wxObjectEventFunction) &interfConfigurationPanel::onBrigthnessColorWindowLevel       ); 
34         Connect( _brithtnessColorLevel->GetId()         ,       wxEVT_SCROLL_CHANGED    , (wxObjectEventFunction) &interfConfigurationPanel::onBrigthnessColorWindowLevel       ); 
35         Connect( _brithtnessColorLevel->GetId()         ,       wxEVT_SCROLL_THUMBTRACK , (wxObjectEventFunction) &interfConfigurationPanel::onBrigthnessColorWindowLevel       ); 
36         Connect( _interpolationCheckBox->GetId()        ,       wxEVT_COMMAND_CHECKBOX_CLICKED    , (wxObjectEventFunction) &interfConfigurationPanel::OnInterpolation          );
37
38         wxFlexGridSizer * sizer                                 = new wxFlexGridSizer(1);
39         sizer -> Add( new wxStaticText(this,-1,_T("Contour width"))  , 1, wxGROW );
40         sizer -> Add( _withOfContourLine                , 1, wxGROW );
41         sizer -> Add( new wxStaticText(this,-1,_T(" "))  , 1, wxGROW );
42         sizer -> Add( new wxStaticText(this,-1,_T(" "))  , 1, wxGROW );
43         sizer -> Add( new wxStaticText(this,-1,_T("Brightness of the image"))  , 1, wxGROW );
44         sizer -> Add( new wxStaticText(this,-1,_T("--Window level--"))  , 1, wxGROW );
45         sizer -> Add( _brithtnessWindowLevel            , 1, wxGROW );
46         sizer -> Add( new wxStaticText(this,-1,_T("--Color level--"))  , 1, wxGROW );
47         sizer -> Add( _brithtnessColorLevel, 1, wxGROW );
48         sizer -> Add( new wxStaticText(this,-1,_T(" "))  , 1, wxGROW );
49         sizer -> Add( new wxStaticText(this,-1,_T(" "))  , 1, wxGROW );
50         sizer -> Add( _interpolationCheckBox            , 1, wxGROW );
51
52         this->SetSizer( sizer );
53         //JCP 13-10-08
54         //panel->SetSize( sizepanel );
55         //13-10-08
56         this->SetAutoLayout( true );
57         this->Layout();
58         
59 }
60
61
62 interfConfigurationPanel::~interfConfigurationPanel()
63 {
64 }
65
66 void interfConfigurationPanel::onWidthOfContour(wxScrollEvent& event){
67
68     double width = (double)_withOfContourLine->GetValue() / 2.0;
69         interfMainPanel::getInstance()->onWidthOfContour(width);
70 }
71
72 void interfConfigurationPanel::onBrigthnessColorWindowLevel(wxScrollEvent& event){
73         int colorwindow                         = _brithtnessColorLevel->GetValue();
74         int windowlevel                         = _brithtnessWindowLevel->GetValue();
75
76
77         interfMainPanel::getInstance()->onBrigthnessColorWindowLevel(colorwindow, windowlevel);
78
79 }
80
81 void interfConfigurationPanel::OnInterpolation(wxCommandEvent& event)
82 {
83         
84         interfMainPanel::getInstance()->onInterpolation(_interpolationCheckBox->GetValue());
85         
86         
87 }
88
89 /**
90 ** Begin of the spread panel
91 **/
92
93 interfSpreadPanel::interfSpreadPanel(wxWindow* parent)
94 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN)
95 {
96
97         //wxPanel *panel                                = new wxPanel(parent,-1);
98
99         //_contourPropagation                   = new ContourPropagation();
100
101         //wxPanel *panel                                                        = new wxPanel(parent,-1,wxDefaultPosition, wxDefaultSize,wxNO_BORDER, wxString("",wxConvUTF8));
102
103         wxButton *spreadResetBtn        = new wxButton(this,-1,_T("Reset"),wxDefaultPosition, wxDefaultSize );
104         wxButton *spreadAddBtn          = new wxButton(this,-1,_T("Add"),wxDefaultPosition, wxDefaultSize);
105
106         wxString lstOptions[3];
107         lstOptions[0]=_T("A");
108         lstOptions[1]=_T("B");
109         lstOptions[2]=_T("C");
110         _spreadMethodRadiobox                                           = new wxRadioBox(this, -1, _T("Method (find ctrl. Points)"), wxDefaultPosition, wxDefaultSize, 3 , lstOptions,  3, wxRA_SPECIFY_COLS);
111         _spreadMethodRadiobox->SetSelection(2);
112
113         wxButton *spreadGoBtn           = new wxButton(this,-1,_T("Go"),wxDefaultPosition, wxDefaultSize);
114         _staticTextSpread                       = new wxStaticText(this,-1,_T("    "));
115
116         _wxtextctrlSpread           = new wxTextCtrl(this,-1, _T(""),wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE );
117         _wxtextctrlSpread->SetEditable(false);
118         
119         Connect( spreadResetBtn->GetId(),       wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfSpreadPanel::onSpreadReset ); 
120         Connect( spreadAddBtn->GetId(),         wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfSpreadPanel::onSpreadAdd ); 
121         Connect( spreadGoBtn->GetId(),          wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfSpreadPanel::onSpreadGo ); 
122
123         wxFlexGridSizer * sizer         = new wxFlexGridSizer(1);
124         sizer -> Add( spreadResetBtn            , 1, wxGROW );
125         sizer -> Add( spreadAddBtn                      , 1, wxGROW );
126         sizer -> Add( _spreadMethodRadiobox     , 1, wxGROW );
127         sizer -> Add( spreadGoBtn                       , 1, wxGROW );
128         sizer -> Add( _staticTextSpread         , 1, wxGROW );
129         sizer -> Add( _wxtextctrlSpread         , 1, wxGROW );
130
131
132         this->SetSizer( sizer );
133         //this->SetSize( wxDefaultSize );
134         this->SetAutoLayout( true );
135         this->Layout();
136         //return panel;
137 }
138
139 interfSpreadPanel::~interfSpreadPanel(){
140 }
141
142 void interfSpreadPanel::onSpreadReset(wxCommandEvent& event){
143         setStringSpread("   ");
144         _wxtextctrlSpread->SetValue(wxString("",wxConvUTF8));
145         interfMainPanel::getInstance()->resetAppend();  
146 }
147 void interfSpreadPanel::onSpreadAdd(wxCommandEvent& event){
148         interfMainPanel::getInstance()->onSpreadAdd();
149 }
150 void interfSpreadPanel::onSpreadGo(wxCommandEvent& event){
151
152
153         setStringSpread("   ");
154         int typeMethodFindCtrlPoints=_spreadMethodRadiobox->GetSelection();
155
156         interfMainPanel::getInstance()->onSpreadGo(typeMethodFindCtrlPoints);
157
158 }
159
160 void interfSpreadPanel::appendStringSpread(std::string val){
161         /* // if */
162         wxString newstring;
163         //newstring.Printf("%s %d -",_wxtextctrlSpread->GetValue(), actualSlice );
164         newstring.append(wxString(_wxtextctrlSpread->GetValue(),wxConvUTF8));
165         newstring.append(wxString(" ",wxConvUTF8));
166         newstring.append(wxString(val.c_str(),wxConvUTF8));
167         _wxtextctrlSpread->SetValue(newstring);
168 }
169
170 void interfSpreadPanel::setStringSpread(std::string stringtemp){
171
172         wxString newstring(stringtemp.c_str(),wxConvUTF8);
173         //_wxtextctrlSpread->SetEditable(true);
174         _staticTextSpread->SetLabel(newstring);
175         //_wxtextctrlSpread->SetEditable(false);
176 }
177
178 /**
179 ** Begin of information panel
180 **/
181 interfInformationPanel::interfInformationPanel(wxWindow * parent)
182 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN){
183
184         //wxPanel *panel                                                                        = new wxPanel(parent,-1,wxDefaultPosition, wxDefaultSize,wxTAB_TRAVERSAL);
185         wxString lstOptions[4];
186         lstOptions[0]=_T("Current Slice");
187         lstOptions[1]=_T("Range Slices");
188         lstOptions[2]=_T("All Slices");
189         _informationRadiobox                                                    = new wxRadioBox(this, -1, _T("Slice analysis"), wxDefaultPosition, wxSize(270,45), 3 , lstOptions,  3, wxRA_SPECIFY_COLS);
190
191         wxString lstOptContOperation[5];
192         lstOptContOperation[0]=_T("AND");
193         lstOptContOperation[1]=_T("OR");
194         lstOptContOperation[2]=_T("XOR");
195         lstOptContOperation[3]=_T("ALL");
196         _radiolstboxContourGroup                                                = new wxRadioBox(this, -1, _T("Contour group"), wxDefaultPosition, wxSize(270,45), 4 , lstOptContOperation,  4, wxRA_SPECIFY_COLS);
197
198         wxButton *informationContourLabelsBtn                   = new wxButton(this,-1,_T("Contour labels"),wxDefaultPosition, wxSize(140,35) );
199         informationContourLabelsBtn->SetEventHandler( this );
200         Connect( informationContourLabelsBtn->GetId(),          wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfInformationPanel::onInformationContourLabels ); 
201
202         wxButton *statisticsContourBtn                                  = new wxButton(this,-1,_T("Contour statistics"),wxDefaultPosition, wxSize(140,35) );
203         statisticsContourBtn->SetEventHandler( this );
204         Connect( statisticsContourBtn->GetId(),         wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfInformationPanel::onExtractInformation ); 
205
206         wxButton *saveResultsBtn                                                = new wxButton(this,-1,_T("Save statistics results"),wxDefaultPosition, wxSize(140,35) );
207         saveResultsBtn->SetEventHandler( this );
208         Connect( saveResultsBtn->GetId(),               wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfInformationPanel::onSaveResults ); 
209
210
211         int sizeZ = interfMainPanel::getInstance()->GetImageDataSizeZ();
212         //_theViewPanel->getSceneManager()->GetImageDataSizeZ();                        
213         _mbarrangeSliceInformation                                      =  new mBarRange(this,65,65);
214         _mbarrangeSliceInformation->SetMin(0);
215         _mbarrangeSliceInformation->SetStart(0);
216         _mbarrangeSliceInformation-> SetOrientation( true );
217         _mbarrangeSliceInformation-> setActiveStateTo(true);
218         _mbarrangeSliceInformation-> setVisibleLabels( true );
219         _mbarrangeSliceInformation-> setDeviceEndMargin(10);
220         _mbarrangeSliceInformation-> setRepresentedValues( 0 , sizeZ-1 );
221         _mbarrangeSliceInformation-> setDeviceBlitStart(10,10); 
222         _mbarrangeSliceInformation-> setIfWithActualDrawed( false );
223         _mbarrangeSliceInformation-> SetStart( 0 );
224         _mbarrangeSliceInformation-> SetEnd( sizeZ-1 );  
225
226
227         double range[2];
228         interfMainPanel::getInstance()->GetImageDataRange(range);
229         //this->_theViewPanel->getSceneManager()->GetImageDataRange(range);
230         _mbarrangeRangeInformation                                      =  new mBarRange(this,65,65);
231         _mbarrangeRangeInformation->SetMin(0);
232         _mbarrangeRangeInformation->SetStart(0);
233         _mbarrangeRangeInformation-> SetOrientation( true );
234         _mbarrangeRangeInformation-> setActiveStateTo(true);
235         _mbarrangeRangeInformation-> setVisibleLabels( true );
236         _mbarrangeRangeInformation-> setDeviceEndMargin(10);
237         _mbarrangeRangeInformation-> setRepresentedValues( range[0] , range[1] );
238         _mbarrangeRangeInformation-> setDeviceBlitStart(10,10); 
239         _mbarrangeRangeInformation-> setIfWithActualDrawed( false );
240         _mbarrangeRangeInformation-> SetStart( range[0] );
241         _mbarrangeRangeInformation-> SetEnd( range[1] );  
242
243
244         _staticTextInformation                                                  = new wxStaticText(this,-1,_T("    "));
245
246
247 //                      wxButton *XXXXXXXBtn                    = new wxButton(this,-1,_T("Statistics"),wxDefaultPosition, wxSize(180,35) );
248 //                      XXXXXXXBtn->SetEventHandler( this );
249 //                      Connect( XXXXXXXBtn->GetId(),           wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &wxContourEventHandler::onXXXXX ); 
250
251
252         _grid = new wxGrid( this,
253                 wxID_ANY,
254                 wxPoint( 0, 0 ),
255                 wxSize( 100, 100 ) );
256
257         int i,gridCol=10,gridRow=sizeZ;
258         _grid->CreateGrid( 0, 0 );
259         _grid->AppendRows(gridRow);
260         _grid->AppendCols(gridCol);
261
262         for (i=0;i<gridRow;i++)
263         {
264                 _grid->SetRowLabelValue(i, _T(" ") );
265         }
266 //                      _grid->SetColLabelSize(0);
267
268
269         FillGridWithContoursInformation();
270
271         wxFlexGridSizer * sizerA                = new wxFlexGridSizer(10);
272         sizerA->Add( _informationRadiobox                       , 1, wxALL ,2 );
273         sizerA->Add( _radiolstboxContourGroup           , 1, wxALL ,2 );
274
275         wxFlexGridSizer * sizerB                = new wxFlexGridSizer(10);
276         sizerB->Add( informationContourLabelsBtn        , 1, wxALL ,2 );
277         sizerB->Add( statisticsContourBtn                       , 1, wxALL ,2 );
278         sizerB->Add( saveResultsBtn                                     , 1, wxALL ,2 );
279
280         wxFlexGridSizer * sizer         = new wxFlexGridSizer(1);
281         sizer->AddGrowableCol(0);
282         sizer->AddGrowableRow(7);
283         sizer->Add( sizerA                                              , 1, wxALL              , 0 );
284         sizer->Add( new wxStaticText(this               ,-1,_T("Slice Range"))  , 1, wxALL              , 0 );
285         sizer->Add( _mbarrangeSliceInformation  , 1, wxALL|wxGROW               , 2 );                  
286         sizer->Add( new wxStaticText(this               ,-1,_T("Gray Range"))   , 1, wxALL              , 0 );
287         sizer->Add( _mbarrangeRangeInformation  , 1, wxALL|wxGROW               , 2 );                  
288         sizer->Add( sizerB                                              , 1, wxALL              , 0 );
289         sizer->Add( _staticTextInformation              , 1, wxALL              , 0 );
290         sizer->Add( _grid                                               , 1, wxEXPAND   , 0 );
291
292
293
294         this->SetSizer( sizer );
295         this->SetSize( wxSize(1500,1500) );
296         //this->SetBackgroundColour( wxColour(100,100,100) );
297         this->SetAutoLayout( true );
298         this->Layout();
299         //return panel;
300 }
301 interfInformationPanel::~interfInformationPanel(){
302 }
303
304 void interfInformationPanel::onInformationContourLabels(wxCommandEvent& event){
305         wxBusyCursor wait;
306         FillGridWithContoursInformation();
307 }
308 void interfInformationPanel::onExtractInformation(wxCommandEvent& event){
309         wxBusyCursor wait;
310         _grid->ClearGrid();
311
312         int typeContourGroup = this->_radiolstboxContourGroup->GetSelection();
313         int selection = _informationRadiobox->GetSelection();
314         int minZ        = _mbarrangeSliceInformation->GetStart();
315         int maxZ        = _mbarrangeSliceInformation->GetEnd();
316
317         interfMainPanel::getInstance()->onInformationContourLabels(typeContourGroup, selection, minZ, maxZ);
318
319         
320 }
321 void interfInformationPanel::onSaveResults(wxCommandEvent& event){
322         wxFileDialog dialog(this, _T("Choose a file"), _T(""), _T(""), _T("*.txt"), wxSAVE );
323         if (dialog.ShowModal() == wxID_OK)
324         {
325                 onExtractInformation( event );
326                 std::string directory=(const char *)(dialog.GetDirectory().mb_str());
327                 std::string namefile=(const char *)(dialog.GetFilename().mb_str());
328                 std::string filename = (const char *)(dialog.GetPath().mb_str() );
329                 int typeContourGroup = _radiolstboxContourGroup->GetSelection();
330                 interfMainPanel::getInstance()->onSaveResults(directory, namefile, filename, typeContourGroup);
331         }
332 }
333
334 void interfInformationPanel::FillGridWithContoursInformation(){
335
336         wxString tempString;
337         _grid->ClearGrid();
338         _grid->SetColLabelValue(0, _T("A") );
339         _grid->SetColLabelValue(1, _T("B") );
340         _grid->SetColLabelValue(2, _T("C") );
341         _grid->SetColLabelValue(3, _T("D") );
342         _grid->SetColLabelValue(4, _T("E") );
343         _grid->SetColLabelValue(5, _T("F") );
344         //_instantPanel->getInstant( tempVector );
345
346         int z,sizeZ = interfMainPanel::getInstance()->GetImageDataSizeZ();//->getSceneManager()->GetImageDataSizeZ();
347         int ii,sizeLstContourThings;
348         for ( z=0 ; z<sizeZ ; z++)
349         {               
350                 
351                 std::vector<std::string> lstContourThings = interfMainPanel::getInstance()->getOutlinesName(z);
352                         
353                         //this->_modelManager->getOutlinesAtInstant( &instant );
354
355                 sizeLstContourThings = lstContourThings.size();
356                 tempString.Printf(_T("%d - %d"),z, sizeLstContourThings);
357                 _grid->SetRowLabelValue(z, tempString );
358
359                 for (ii=0 ; ii<sizeLstContourThings ; ii++)
360                 {
361                         //ContourThing **contourthing = lstContourThings[ii];
362                         //tempString = wxString((*contourthing)->getName().c_str(),wxConvUTF8) ;
363                         tempString = wxString(lstContourThings[ii].c_str(),wxConvUTF8) ;
364                         _grid->SetCellValue( z, ii, tempString );
365                 }
366         }
367 }
368
369 void interfInformationPanel::setStringInfoPanel(wxString tmpString){
370         _staticTextInformation->SetLabel(tmpString);
371 }
372
373 void interfInformationPanel::setRowLabelInfoPanel(int z,wxString tempString){
374         _grid->SetRowLabelValue(z, tempString );
375 }
376
377 int interfInformationPanel::getNumberCols(){
378         return _grid->GetNumberCols();
379 }
380
381 void interfInformationPanel::appendCols(int numcols){
382     _grid->AppendCols(numcols);
383 }
384
385 void interfInformationPanel::setCellValue(int z,int tmpIntA,wxString tempString){
386         _grid->SetCellValue( z, tmpIntA , tempString );
387 }
388
389 void interfInformationPanel::setColLabel(int tmpIntB,wxString tmpTitleString){
390         _grid->SetColLabelValue(tmpIntB, tmpTitleString);
391 }
392
393 wxString interfInformationPanel::getCellValue(int j,int i){
394         return _grid->GetCellValue( j , i );
395 }
396
397
398
399 /**
400 ** Begin of the mirror panel
401 **/
402
403 interfMirrorPanel::interfMirrorPanel(wxWindow* parent)
404 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN)
405 {
406         wxButton *mirrorGoBtn = new wxButton(this,-1,_T("Go"), wxDefaultPosition, wxSize(200,35) );
407         _thickness = new wxSlider(this, -1, 0 , 0, 10, wxDefaultPosition, wxSize(200,35), wxSL_HORIZONTAL|wxSL_LABELS, wxDefaultValidator);
408         
409         Connect( mirrorGoBtn->GetId(),          wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfMirrorPanel::onMirrorGo ); 
410
411         wxFlexGridSizer * sizer         = new wxFlexGridSizer(1);
412         sizer -> Add( new wxStaticText(this,-1,_T("Thickness"))  , 1, wxGROW );
413         sizer -> Add( _thickness, 1, wxGROW );
414         sizer -> Add( mirrorGoBtn, 1, wxGROW );
415
416         this->SetSizer( sizer );
417         this->SetAutoLayout( true );
418         this->Layout();
419 }
420
421 interfMirrorPanel::~interfMirrorPanel(){
422 }
423
424 void interfMirrorPanel::onMirrorGo(wxCommandEvent& event)
425 {
426         //wxString thick=_thickness->GetValue();
427         interfMainPanel::getInstance()->onMirror();
428 }