]> Creatis software - creaContours.git/blob - lib/Interface_Icons_NDimensions/interfToolsPanels.cxx
no message
[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()->getImageRange(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         int min = (int)floor (range[0]);
23         int max = (int)ceil (range[1]);
24
25
26         _brithtnessWindowLevel                                  = new wxSlider(this, -1, windowlevel , min, max, wxDefaultPosition, wxDefaultSize, wxSL_HORIZONTAL|wxSL_LABELS, wxDefaultValidator);
27         _brithtnessColorLevel                                   = new wxSlider(this, -1, colorwindow , min, max, wxDefaultPosition, wxDefaultSize, wxSL_HORIZONTAL|wxSL_LABELS, wxDefaultValidator);
28
29         _interpolationCheckBox = new wxCheckBox(this, -1, _T("Image interpolation") );
30         _interpolationCheckBox->SetValue(true);
31
32         Connect( _withOfContourLine->GetId(),     wxEVT_SCROLL_CHANGED,           (wxObjectEventFunction) &interfConfigurationPanel::onWidthOfContour);
33         Connect( _withOfContourLine->GetId(),     wxEVT_SCROLL_THUMBTRACK,        (wxObjectEventFunction) &interfConfigurationPanel::onWidthOfContour);
34
35         Connect( _brithtnessWindowLevel->GetId(), wxEVT_SCROLL_CHANGED,           (wxObjectEventFunction) &interfConfigurationPanel::onBrigthnessColorWindowLevel);
36         Connect( _brithtnessWindowLevel->GetId(), wxEVT_SCROLL_THUMBTRACK,        (wxObjectEventFunction) &interfConfigurationPanel::onBrigthnessColorWindowLevel);
37         Connect( _brithtnessColorLevel->GetId() , wxEVT_SCROLL_CHANGED,           (wxObjectEventFunction) &interfConfigurationPanel::onBrigthnessColorWindowLevel);
38         Connect( _brithtnessColorLevel->GetId() , wxEVT_SCROLL_THUMBTRACK,        (wxObjectEventFunction) &interfConfigurationPanel::onBrigthnessColorWindowLevel);
39         Connect( _interpolationCheckBox->GetId(), wxEVT_COMMAND_CHECKBOX_CLICKED, (wxObjectEventFunction) &interfConfigurationPanel::OnInterpolation);
40
41         wxFlexGridSizer * sizer                                 = new wxFlexGridSizer(1);
42         sizer -> Add( new wxStaticText(this,-1, _T("Contour width"))  , 1, wxGROW );
43         sizer -> Add( _withOfContourLine                , 1, wxGROW );
44         sizer -> Add( new wxStaticText(this,-1, _T(" "))  , 1, wxGROW );
45         sizer -> Add( new wxStaticText(this,-1, _T(" "))  , 1, wxGROW );
46         sizer -> Add( new wxStaticText(this,-1, _T("Brightness of the image"))  , 1, wxGROW );
47         sizer -> Add( new wxStaticText(this,-1, _T("--Window level--"))  , 1, wxGROW );
48         sizer -> Add( _brithtnessWindowLevel            , 1, wxGROW );
49         sizer -> Add( new wxStaticText(this,-1, _T("--Color level--"))  , 1, wxGROW );
50         sizer -> Add( _brithtnessColorLevel, 1, wxGROW );
51         sizer -> Add( new wxStaticText(this,-1, _T(" "))  , 1, wxGROW );
52         sizer -> Add( new wxStaticText(this,-1, _T(" "))  , 1, wxGROW );
53         sizer -> Add( _interpolationCheckBox            , 1, wxGROW );
54
55         this->SetSizer( sizer );
56         //JCP 13-10-08
57         //panel->SetSize( sizepanel );
58         //13-10-08
59         this->SetAutoLayout( true );
60         this->Layout();
61
62 }
63
64
65 interfConfigurationPanel::~interfConfigurationPanel()
66 {
67 }
68
69 void interfConfigurationPanel::onWidthOfContour(wxScrollEvent& event){
70
71     double width = (double)_withOfContourLine->GetValue() / 2.0;
72         interfMainPanel::getInstance()->onWidthOfContour(width);
73 }
74
75 void interfConfigurationPanel::onBrigthnessColorWindowLevel(wxScrollEvent& event){
76         int colorwindow                         = _brithtnessColorLevel->GetValue();
77         int windowlevel                         = _brithtnessWindowLevel->GetValue();
78
79         interfMainPanel::getInstance()->onBrigthnessColorWindowLevel(colorwindow, windowlevel);
80
81 }
82
83 void interfConfigurationPanel::OnInterpolation(wxCommandEvent& event)
84 {
85
86         interfMainPanel::getInstance()->onInterpolation(_interpolationCheckBox->GetValue());
87
88
89 }
90
91 /**
92 ** Begin of the spread panel
93 **/
94
95 interfSpreadPanel::interfSpreadPanel(wxWindow* parent)
96 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN)
97 {
98
99         //wxPanel *panel                                = new wxPanel(parent,-1);
100
101         //_contourPropagation                   = new ContourPropagation();
102
103         //wxPanel *panel                                                        = new wxPanel(parent,-1,wxDefaultPosition, wxDefaultSize,wxNO_BORDER, wxString("",wxConvUTF8));
104
105         wxButton *spreadResetBtn        = new wxButton(this,-1,_T("Reset"),wxDefaultPosition, wxDefaultSize );
106         wxButton *spreadAddBtn          = new wxButton(this,-1,_T("Add key contour "),wxDefaultPosition, wxDefaultSize);
107         wxButton *spreadAddAllBtn       = new wxButton(this,-1,_T("Add All to key contour"),wxDefaultPosition, wxDefaultSize);
108
109         wxString lstOptions[3];
110         lstOptions[0]=_T("A");
111         lstOptions[1]=_T("B");
112         lstOptions[2]=_T("C");
113         _spreadMethodRadiobox                                           = new wxRadioBox(this, -1, _T("Method (find ctrl. Points)"), wxDefaultPosition, wxDefaultSize, 3 , lstOptions,  3, wxRA_SPECIFY_COLS);
114         _spreadMethodRadiobox->SetSelection(2);
115
116         wxButton *spreadGoBtn           = new wxButton(this,-1,_T("Go"),wxDefaultPosition, wxDefaultSize);
117         _staticTextSpread                       = new wxStaticText(this,-1,_T("    "));
118
119         _wxtextctrlSpread           = new wxTextCtrl(this,-1, _T(""),wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE );
120         _wxtextctrlSpread->SetEditable(false);
121
122         Connect( spreadResetBtn->GetId(),       wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfSpreadPanel::onSpreadReset );
123         Connect( spreadAddBtn->GetId(),         wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfSpreadPanel::onSpreadAdd );
124         Connect( spreadAddAllBtn->GetId(),      wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfSpreadPanel::onSpreadAddAll );
125         Connect( spreadGoBtn->GetId(),          wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfSpreadPanel::onSpreadGo );
126
127         wxFlexGridSizer * sizer         = new wxFlexGridSizer(1);
128         sizer -> Add( spreadResetBtn            , 1, wxGROW );
129         sizer -> Add( spreadAddBtn                      , 1, wxGROW );
130         sizer -> Add( spreadAddAllBtn           , 1, wxGROW );
131         sizer -> Add( _spreadMethodRadiobox     , 1, wxGROW );
132         sizer -> Add( spreadGoBtn                       , 1, wxGROW );
133         sizer -> Add( _staticTextSpread         , 1, wxGROW );
134         sizer -> Add( _wxtextctrlSpread         , 1, wxGROW );
135
136
137         this->SetSizer( sizer );
138         //this->SetSize( wxDefaultSize );
139         this->SetAutoLayout( true );
140         this->Layout();
141         //return panel;
142 }
143
144 interfSpreadPanel::~interfSpreadPanel(){
145 }
146
147 void interfSpreadPanel::onSpreadReset(wxCommandEvent& event){
148         setStringSpread("   ");
149         _wxtextctrlSpread->SetValue(wxString("",wxConvUTF8));
150         interfMainPanel::getInstance()->resetAppend();
151 }
152
153 void interfSpreadPanel::onSpreadAdd(wxCommandEvent& event){
154         interfMainPanel::getInstance()->onSpreadAdd();
155 }
156
157 void interfSpreadPanel::onSpreadAddAll(wxCommandEvent& event){
158         interfMainPanel::getInstance()->onSpreadAddAll();
159 }
160
161 void interfSpreadPanel::onSpreadGo(wxCommandEvent& event){
162         setStringSpread("   ");
163         int typeMethodFindCtrlPoints=_spreadMethodRadiobox->GetSelection();
164 printf("EED interfSpreadPanel::onSpreadGo %d\n",typeMethodFindCtrlPoints);
165         interfMainPanel::getInstance()->onSpreadGo(typeMethodFindCtrlPoints);
166
167 }
168
169 void interfSpreadPanel::appendStringSpread(std::string val){
170         /* // if */
171         wxString newstring;
172         //newstring.Printf("%s %d -",_wxtextctrlSpread->GetValue(), actualSlice );
173         newstring.append(wxString(_wxtextctrlSpread->GetValue(),wxConvUTF8));
174         newstring.append(wxString(" ",wxConvUTF8));
175         newstring.append(wxString(val.c_str(),wxConvUTF8));
176         _wxtextctrlSpread->SetValue(newstring);
177 }
178
179 void interfSpreadPanel::setStringSpread(std::string stringtemp){
180
181         wxString newstring(stringtemp.c_str(),wxConvUTF8);
182         //_wxtextctrlSpread->SetEditable(true);
183         _staticTextSpread->SetLabel(newstring);
184         //_wxtextctrlSpread->SetEditable(false);
185 }
186
187 /**
188 ** Begin of information panel
189 **/
190 interfInformationPanel::interfInformationPanel(wxWindow * parent)
191 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN)
192 {
193         //wxPanel *panel                                                                        = new wxPanel(parent,-1,wxDefaultPosition, wxDefaultSize,wxTAB_TRAVERSAL);
194         wxString lstOptions[4];
195         lstOptions[0]=_T("Current Slice");
196         lstOptions[1]=_T("Range Slices");
197 //      lstOptions[2]=_T("All Slices");
198         _informationRadiobox     = new wxRadioBox(this, -1, _T("Slice analysis"), wxDefaultPosition, wxSize(270,45), 2 , lstOptions,  2, wxRA_SPECIFY_COLS);
199
200
201         wxString lstOptContOperation[5];
202         lstOptContOperation[0]=_T("AND");
203         lstOptContOperation[1]=_T("OR");
204         lstOptContOperation[2]=_T("XOR");
205         lstOptContOperation[3]=_T("ALL");
206         _radiolstboxContourGroup = new wxRadioBox(this, -1, _T("Contour group"), wxDefaultPosition, wxSize(270,45), 4 , lstOptContOperation,  4, wxRA_SPECIFY_COLS);
207         _radiolstboxContourGroup->SetSelection(1);
208         Connect( _radiolstboxContourGroup->GetId(), wxEVT_COMMAND_RADIOBOX_SELECTED , (wxObjectEventFunction) &interfInformationPanel::onContourGroup );
209
210
211         _XYZValues = new wxCheckBox(this, -1, _T("Save Contour Values") );
212         _XYZValues->SetValue(true);
213
214         _contourImage = new wxCheckBox(this, -1, _T("Extract Contours as Images") );
215         _contourImage->SetValue(true);
216
217         _statistics = new wxCheckBox(this, -1, _T("Save Statistics") );
218         _statistics->SetValue(true);
219
220         wxButton *informationContourLabelsBtn           = new wxButton(this,-1,_T("Contour labels"),wxDefaultPosition, wxSize(140,35) );
221         informationContourLabelsBtn->SetEventHandler( this );
222         Connect( informationContourLabelsBtn->GetId(),          wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfInformationPanel::onInformationContourLabels );
223
224         wxButton *statisticsContourBtn                  = new wxButton(this,-1,_T("Contour statistics"),wxDefaultPosition, wxSize(140,35) );
225         statisticsContourBtn->SetEventHandler( this );
226         Connect( statisticsContourBtn->GetId(),         wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfInformationPanel::onExtractInformation );
227
228         wxButton *showResultImagesBtn                   = new wxButton(this,-1,_T("Show result images"),wxDefaultPosition, wxSize(140,35) );
229         showResultImagesBtn->SetEventHandler( this );
230         Connect( showResultImagesBtn->GetId(),          wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfInformationPanel::onShowResultImages );
231
232
233         wxButton *saveResultsBtn                        = new wxButton(this,-1,_T("Save Results"),wxDefaultPosition, wxSize(140,35) );
234         saveResultsBtn->SetEventHandler( this );
235         Connect( saveResultsBtn->GetId(),               wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfInformationPanel::onSaveResults );
236
237
238         int sizeZ = interfMainPanel::getInstance()->GetImageDataSizeZ();
239         //_theViewPanel->getSceneManager()->GetImageDataSizeZ();
240         _mbarrangeSliceInformation                      =  new mBarRange(this,65,65);
241         _mbarrangeSliceInformation->SetMin(0);
242         _mbarrangeSliceInformation->SetStart(0);
243         _mbarrangeSliceInformation-> SetOrientation( true );
244         _mbarrangeSliceInformation-> setActiveStateTo(true);
245         _mbarrangeSliceInformation-> setVisibleLabels( true );
246         _mbarrangeSliceInformation-> setDeviceEndMargin(10);
247         _mbarrangeSliceInformation-> setRepresentedValues( 0 , sizeZ-1 );
248         _mbarrangeSliceInformation-> setDeviceBlitStart(10,10);
249         _mbarrangeSliceInformation-> setIfWithActualDrawed( false );
250         _mbarrangeSliceInformation-> SetStart( 0 );
251         _mbarrangeSliceInformation-> SetEnd( sizeZ-1 );
252
253
254
255         double range[2];
256         interfMainPanel::getInstance()->getImageRange(range);
257
258         int min = (int)floor (range[0]);
259         int max = (int)ceil (range[1]);
260
261         _mbarrangeRangeInformation      =  new mBarRange(this,65,65);
262         _mbarrangeRangeInformation->SetMin(0);
263         _mbarrangeRangeInformation->SetStart(0);
264         _mbarrangeRangeInformation->SetOrientation( true );
265         _mbarrangeRangeInformation->setActiveStateTo(true);
266         _mbarrangeRangeInformation->setVisibleLabels( true );
267         _mbarrangeRangeInformation->setDeviceEndMargin(10);
268         _mbarrangeRangeInformation->setRepresentedValues( min , max );
269         _mbarrangeRangeInformation->setDeviceBlitStart(10,10);
270         _mbarrangeRangeInformation->setIfWithActualDrawed( false );
271         _mbarrangeRangeInformation->SetStart( min );
272         _mbarrangeRangeInformation->SetEnd( max );
273
274 //      _mbarrangeSliceInformation->PushEventHandler(this);
275 //      Connect(_mbarrangeRangeInformation->GetId(),wxEVT_TSBAR,(wxObjectEventFunction) (wxCommandEventFunction) &interfInformationPanel::onRangeSliceInformation );
276 //      Connect(_mbarrangeRangeInformation->GetId(),wxEVT_TSBAR_ACTUAL,(wxObjectEventFunction) (wxCommandEventFunction)  &interfInformationPanel::onRangeSliceInformation );
277         Connect(_mbarrangeRangeInformation->GetId(),wxEVT_TSBAR_START,(wxObjectEventFunction) (wxCommandEventFunction)  &interfInformationPanel::onRangeSliceInformation );
278         Connect(_mbarrangeRangeInformation->GetId(),wxEVT_TSBAR_END,(wxObjectEventFunction) (wxCommandEventFunction)  &interfInformationPanel::onRangeSliceInformation );
279 //      Connect(_mbarrangeRangeInformation->GetId(),wxEVT_SELECTION_END,(wxObjectEventFunction) (wxCommandEventFunction)  &interfInformationPanel::onRangeSliceInformation );
280         Connect(_mbarrangeRangeInformation->GetId(),wxEVT_TSBAR_MOVED,(wxObjectEventFunction) (wxCommandEventFunction)  &interfInformationPanel::onRangeSliceInformation );
281
282
283         _staticTextInformation  = new wxStaticText(this,-1,_T("    "));
284
285         _grid = new wxGrid( this,
286                 wxID_ANY,
287                 wxPoint( 0, 0 ),
288                 wxSize( 200, 500 ) );
289
290         int i,gridCol=10,gridRow=sizeZ+2;
291         _grid->CreateGrid( 0, 0 );
292         _grid->AppendRows(gridRow);
293         _grid->AppendCols(gridCol);
294
295         for (i=0;i<gridRow;i++)
296         {
297                 _grid->SetRowLabelValue(i, _T(" ") );
298         }
299 //                      _grid->SetColLabelSize(0);
300
301
302         FillGridWithContoursInformation();
303
304         wxFlexGridSizer * sizerSave             = new wxFlexGridSizer(2,2);
305         sizerSave -> Add( new wxStaticText(this,-1,_T("Save Options: "))  , 1, wxGROW );
306         sizerSave->Add( _XYZValues,    1, wxALL, 2 );
307         sizerSave->Add( _statistics,   1, wxALL, 2 );
308         sizerSave->Add( _contourImage, 1, wxALL, 2 );
309
310         wxFlexGridSizer * sizerA                = new wxFlexGridSizer(10);
311         sizerA->Add( _informationRadiobox,     1, wxALL, 2 );
312         sizerA->Add( _radiolstboxContourGroup, 1, wxALL, 2 );
313         sizerA->Add( sizerSave,                1, wxALL, 2 );
314
315
316         wxFlexGridSizer * sizerB                = new wxFlexGridSizer(10);
317         sizerB->Add( informationContourLabelsBtn, 1, wxALL, 2 );
318         sizerB->Add( statisticsContourBtn,        1, wxALL, 2 );
319         sizerB->Add( showResultImagesBtn,         1, wxALL, 2 );
320         sizerB->Add( saveResultsBtn,              1, wxALL, 2 );
321
322         wxFlexGridSizer * sizer         = new wxFlexGridSizer(1,8);
323         sizer->Add( sizerA                     , 1, wxALL               , 0 );
324         sizer->Add( new wxStaticText(this      ,-1,_T("Slice Range"))   , 1, wxALL , 0 );
325         sizer->Add( _mbarrangeSliceInformation , 1, wxALL|wxGROW        , 2 );
326         sizer->Add( new wxStaticText(this      ,-1,_T("Gray Range"))    , 1, wxALL , 0 );
327         sizer->Add( _mbarrangeRangeInformation , 1, wxALL|wxGROW        , 2 );
328         sizer->Add( sizerB                     , 1, wxEXPAND            , 0 );
329         sizer->Add( _staticTextInformation     , 1, wxEXPAND            , 0 );
330         sizer->Add( _grid                      , 1, wxEXPAND            , 0 );
331
332         this->SetSizer( sizer );
333         this->SetSize( wxSize(1500,1500) );
334         //this->SetBackgroundColour( wxColour(100,100,100) );
335         this->SetAutoLayout( true );
336         this->Layout();
337         //return panel;
338 }
339
340 interfInformationPanel::~interfInformationPanel()
341 {
342 }
343
344
345 void interfInformationPanel::onRangeSliceInformation(wxCommandEvent& event)
346 {
347         int     grayRangeMin    = _mbarrangeRangeInformation->GetStart();
348         int     grayRangeMax    = _mbarrangeRangeInformation->GetEnd();
349         interfMainPanel::getInstance()->SetScalarRange(grayRangeMin,grayRangeMax);
350         interfMainPanel::getInstance()->RefreshInterface();
351 }
352
353
354 void interfInformationPanel::onInformationContourLabels(wxCommandEvent& event){
355         wxBusyCursor wait;
356         FillGridWithContoursInformation();
357 }
358
359
360 void interfInformationPanel::onShowResultImages(wxCommandEvent& event)
361 {
362 //      onExtractInformation( event );
363         int selection        = _informationRadiobox->GetSelection();
364         int minZ             = _mbarrangeSliceInformation->GetStart();
365         int maxZ             = _mbarrangeSliceInformation->GetEnd();
366         int typeContourGroup = _radiolstboxContourGroup->GetSelection();
367         interfMainPanel::getInstance()->ShowResultImages(typeContourGroup, selection, minZ, maxZ);
368 }
369
370
371 void interfInformationPanel::onExtractInformation(wxCommandEvent& event){
372         wxBusyCursor wait;
373         _grid->ClearGrid();
374
375         int typeContourGroup = this->_radiolstboxContourGroup->GetSelection();
376         int selection        = _informationRadiobox->GetSelection();
377         int minZ             = _mbarrangeSliceInformation->GetStart();
378         int maxZ             = _mbarrangeSliceInformation->GetEnd();
379         int grayRangeMin     = _mbarrangeRangeInformation->GetStart();
380         int grayRangeMax     = _mbarrangeRangeInformation->GetEnd();
381
382         interfMainPanel::getInstance()->onInformationContourLabels(typeContourGroup, selection, minZ, maxZ, grayRangeMin, grayRangeMax);
383 }
384
385 void interfInformationPanel::onSaveResults(wxCommandEvent& event)
386 {
387         wxFileDialog dialog(this, _T("Choose a filename"), _T(""), _T(""), wxFileSelectorDefaultWildcardStr, wxSAVE );
388         if (dialog.ShowModal() == wxID_OK)
389         {
390                 onExtractInformation( event );
391                 int selection         = _informationRadiobox->GetSelection();
392                 int minZ              = _mbarrangeSliceInformation->GetStart();
393                 int maxZ              = _mbarrangeSliceInformation->GetEnd();
394                 std::string directory = (const char *)(dialog.GetDirectory().mb_str());
395                 std::string namefile  = (const char *)(dialog.GetFilename().mb_str());
396                 std::string filename  = (const char *)(dialog.GetPath().mb_str() );
397                 int typeContourGroup  = _radiolstboxContourGroup->GetSelection();
398                 interfMainPanel::getInstance()->onSaveResults(directory, namefile, filename,
399                         typeContourGroup,
400                         selection,minZ,maxZ,
401                         _XYZValues->GetValue(), _contourImage->GetValue(), _statistics->GetValue());
402         }
403 }
404
405 void interfInformationPanel::FillGridWithContoursInformation(){
406
407         wxString tempString;
408         _grid->ClearGrid();
409         _grid->SetColLabelValue(0, _T("A") );
410         _grid->SetColLabelValue(1, _T("B") );
411         _grid->SetColLabelValue(2, _T("C") );
412         _grid->SetColLabelValue(3, _T("D") );
413         _grid->SetColLabelValue(4, _T("E") );
414         _grid->SetColLabelValue(5, _T("F") );
415         //_instantPanel->getInstant( tempVector );
416
417         int z,sizeZ = interfMainPanel::getInstance()->GetImageDataSizeZ();//->getSceneManager()->GetImageDataSizeZ();
418         int ii,sizeLstContourThings;
419         for ( z=0 ; z<sizeZ ; z++)
420         {
421
422                 std::vector<std::string> lstContourThings = interfMainPanel::getInstance()->getOutlinesName(z);
423
424                         //this->_modelManager->getOutlinesAtInstant( &instant );
425
426                 sizeLstContourThings = lstContourThings.size();
427                 tempString.Printf(_T("%d - %d"),z, sizeLstContourThings);
428                 _grid->SetRowLabelValue(z, tempString );
429
430                 for (ii=0 ; ii<sizeLstContourThings ; ii++)
431                 {
432                         //ContourThing **contourthing = lstContourThings[ii];
433                         //tempString = wxString((*contourthing)->getName().c_str(),wxConvUTF8) ;
434                         tempString = wxString(lstContourThings[ii].c_str(),wxConvUTF8) ;
435                         _grid->SetCellValue( z, ii, tempString );
436                 } // for ii
437         }// for z
438
439         // Last line
440         _grid->SetRowLabelValue(sizeZ, _T(" ") );
441         for (ii=0 ; ii<sizeLstContourThings ; ii++)
442         {
443                 _grid->SetCellValue( sizeZ, ii, _T(" ") );
444         } // for ii
445
446 }
447
448 void interfInformationPanel::setStringInfoPanel(wxString tmpString){
449         _staticTextInformation->SetLabel(tmpString);
450 }
451
452 void interfInformationPanel::setRowLabelInfoPanel(int z,wxString tempString){
453         _grid->SetRowLabelValue(z, tempString );
454 }
455
456 int interfInformationPanel::getNumberCols(){
457         return _grid->GetNumberCols();
458 }
459
460 void interfInformationPanel::appendCols(int numcols){
461     _grid->AppendCols(numcols);
462 }
463
464 void interfInformationPanel::setCellValue(int z,int tmpIntA,wxString tempString){
465         _grid->SetCellValue( z, tmpIntA , tempString );
466 }
467
468 void interfInformationPanel::setColLabel(int tmpIntB,wxString tmpTitleString){
469         _grid->SetColLabelValue(tmpIntB, tmpTitleString);
470 }
471
472 wxString interfInformationPanel::getCellValue(int j,int i){
473         return _grid->GetCellValue( j , i );
474 }
475
476 void interfInformationPanel::onContourGroup(wxCommandEvent& event)
477 {
478         printf("EED interfInformationPanel::onContourGroup \n");
479         int contourGroup=_radiolstboxContourGroup->GetSelection();
480         if (contourGroup==3)
481         {
482                 contourGroup=0;
483         }
484         interfMainPanel::getInstance()->SetContourGroup( _radiolstboxContourGroup->GetSelection() );
485 }
486
487 //CMRU 29-08-09-----------------------------------------------------------------------------------------------
488 interfCalibrationPanel:: interfCalibrationPanel(wxWindow * parent)
489 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN)
490 {
491         double range[2];
492         interfMainPanel::getInstance()->getImageRange(range);
493
494         //Radio buttons
495         wxString options[3];
496         options[0]=_T("mm");
497         options[1]=_T("cm");
498         options[2]=_T("inch");
499
500         _unitsRadiobox = new wxRadioBox(this, -1, _T("Unit of measurement"), wxPoint(2, 25), wxSize(145,45), 3 , options,  3, wxRA_SPECIFY_COLS);
501         _unitsRadiobox->SetSelection(0);
502
503         //The label
504         new wxStaticText(this, wxID_ANY, wxT("Real Size: "),   wxPoint(2, 5));
505
506         //Text Control
507         _size = new wxTextCtrl(this, wxID_ANY, wxT(""),  wxPoint(78,3),   wxSize(70, 20), 0, wxDefaultValidator, wxTextCtrlNameStr);
508
509         //The button
510         new wxButton(this, 1, wxT("Calibrate"), wxPoint(78, 70), wxSize(70, 25), 0, wxDefaultValidator, wxT("button"));
511
512         //Conexion del boton con su respectivo manejador
513         Connect(1, wxEVT_COMMAND_BUTTON_CLICKED,(wxObjectEventFunction) &interfCalibrationPanel::onCalibrate);
514
515 }
516
517 interfCalibrationPanel:: ~interfCalibrationPanel()
518 {
519 }
520
521 void interfCalibrationPanel::onCalibrate(wxCommandEvent& event)
522 {
523         wxString size =_size->GetValue();
524         int unit = _unitsRadiobox->GetSelection();
525         interfMainPanel::getInstance()->onCalibration(size, unit);
526 }
527 //------------------------------------------------------------------------------------------------------------
528