1 #include "interfToolsPanels.h"
2 #include "interfMainPanel.h"
4 interfConfigurationPanel::interfConfigurationPanel(wxWindow * parent)
5 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN)
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);
11 interfMainPanel::getInstance()->getImageRange(range);
12 //this->_theViewPanel->getSceneManager()->GetImageDataRange(range);
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();
19 int colorwindow = interfMainPanel::getInstance()->getColorWindow();
20 int windowlevel = interfMainPanel::getInstance()->getWindowLevel();
22 int min = (int)floor (range[0]);
23 int max = (int)ceil (range[1]);
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);
29 _interpolationCheckBox = new wxCheckBox(this, -1, _T("Image interpolation") );
30 _interpolationCheckBox->SetValue(true);
32 Connect( _withOfContourLine->GetId(), wxEVT_SCROLL_CHANGED, (wxObjectEventFunction) &interfConfigurationPanel::onWidthOfContour);
33 Connect( _withOfContourLine->GetId(), wxEVT_SCROLL_THUMBTRACK, (wxObjectEventFunction) &interfConfigurationPanel::onWidthOfContour);
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);
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 );
55 this->SetSizer( sizer );
57 //panel->SetSize( sizepanel );
59 this->SetAutoLayout( true );
65 interfConfigurationPanel::~interfConfigurationPanel()
69 void interfConfigurationPanel::onWidthOfContour(wxScrollEvent& event){
71 double width = (double)_withOfContourLine->GetValue() / 2.0;
72 interfMainPanel::getInstance()->onWidthOfContour(width);
75 void interfConfigurationPanel::onBrigthnessColorWindowLevel(wxScrollEvent& event){
76 int colorwindow = _brithtnessColorLevel->GetValue();
77 int windowlevel = _brithtnessWindowLevel->GetValue();
79 interfMainPanel::getInstance()->onBrigthnessColorWindowLevel(colorwindow, windowlevel);
83 void interfConfigurationPanel::OnInterpolation(wxCommandEvent& event)
86 interfMainPanel::getInstance()->onInterpolation(_interpolationCheckBox->GetValue());
92 ** Begin of the spread panel
95 interfSpreadPanel::interfSpreadPanel(wxWindow* parent)
96 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN)
99 //wxPanel *panel = new wxPanel(parent,-1);
101 //_contourPropagation = new ContourPropagation();
103 //wxPanel *panel = new wxPanel(parent,-1,wxDefaultPosition, wxDefaultSize,wxNO_BORDER, wxString("",wxConvUTF8));
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);
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);
116 wxButton *spreadGoBtn = new wxButton(this,-1,_T("Go"),wxDefaultPosition, wxDefaultSize);
117 _staticTextSpread = new wxStaticText(this,-1,_T(" "));
119 _wxtextctrlSpread = new wxTextCtrl(this,-1, _T(""),wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE );
120 _wxtextctrlSpread->SetEditable(false);
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 );
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 );
137 this->SetSizer( sizer );
138 //this->SetSize( wxDefaultSize );
139 this->SetAutoLayout( true );
144 interfSpreadPanel::~interfSpreadPanel(){
147 void interfSpreadPanel::onSpreadReset(wxCommandEvent& event){
148 setStringSpread(" ");
149 _wxtextctrlSpread->SetValue(wxString("",wxConvUTF8));
150 interfMainPanel::getInstance()->resetAppend();
153 void interfSpreadPanel::onSpreadAdd(wxCommandEvent& event){
154 interfMainPanel::getInstance()->onSpreadAdd();
157 void interfSpreadPanel::onSpreadAddAll(wxCommandEvent& event){
158 interfMainPanel::getInstance()->onSpreadAddAll();
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);
169 void interfSpreadPanel::appendStringSpread(std::string val){
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);
179 void interfSpreadPanel::setStringSpread(std::string stringtemp){
181 wxString newstring(stringtemp.c_str(),wxConvUTF8);
182 //_wxtextctrlSpread->SetEditable(true);
183 _staticTextSpread->SetLabel(newstring);
184 //_wxtextctrlSpread->SetEditable(false);
188 ** Begin of information panel
190 interfInformationPanel::interfInformationPanel(wxWindow * parent)
191 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN)
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);
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 );
211 _XYZValues = new wxCheckBox(this, -1, _T("Save Contour Values") );
212 _XYZValues->SetValue(true);
214 _contourImage = new wxCheckBox(this, -1, _T("Extract Contours as Images") );
215 _contourImage->SetValue(true);
217 _statistics = new wxCheckBox(this, -1, _T("Save Statistics") );
218 _statistics->SetValue(true);
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 );
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 );
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 );
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 );
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 );
256 interfMainPanel::getInstance()->getImageRange(range);
258 int min = (int)floor (range[0]);
259 int max = (int)ceil (range[1]);
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 );
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 );
283 _staticTextInformation = new wxStaticText(this,-1,_T(" "));
285 _grid = new wxGrid( this,
288 wxSize( 200, 500 ) );
290 int i,gridCol=10,gridRow=sizeZ+2;
291 _grid->CreateGrid( 0, 0 );
292 _grid->AppendRows(gridRow);
293 _grid->AppendCols(gridCol);
295 for (i=0;i<gridRow;i++)
297 _grid->SetRowLabelValue(i, _T(" ") );
299 // _grid->SetColLabelSize(0);
302 FillGridWithContoursInformation();
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 );
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 );
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 );
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 );
332 this->SetSizer( sizer );
333 this->SetSize( wxSize(1500,1500) );
334 //this->SetBackgroundColour( wxColour(100,100,100) );
335 this->SetAutoLayout( true );
340 interfInformationPanel::~interfInformationPanel()
345 void interfInformationPanel::onRangeSliceInformation(wxCommandEvent& event)
347 int grayRangeMin = _mbarrangeRangeInformation->GetStart();
348 int grayRangeMax = _mbarrangeRangeInformation->GetEnd();
349 interfMainPanel::getInstance()->SetScalarRange(grayRangeMin,grayRangeMax);
350 interfMainPanel::getInstance()->RefreshInterface();
354 void interfInformationPanel::onInformationContourLabels(wxCommandEvent& event){
356 FillGridWithContoursInformation();
360 void interfInformationPanel::onShowResultImages(wxCommandEvent& event)
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);
371 void interfInformationPanel::onExtractInformation(wxCommandEvent& event){
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();
382 interfMainPanel::getInstance()->onInformationContourLabels(typeContourGroup, selection, minZ, maxZ, grayRangeMin, grayRangeMax);
385 void interfInformationPanel::onSaveResults(wxCommandEvent& event)
387 wxFileDialog dialog(this, _T("Choose a filename"), _T(""), _T(""), wxFileSelectorDefaultWildcardStr, wxSAVE );
388 if (dialog.ShowModal() == wxID_OK)
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,
401 _XYZValues->GetValue(), _contourImage->GetValue(), _statistics->GetValue());
405 void interfInformationPanel::FillGridWithContoursInformation(){
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 );
417 int z,sizeZ = interfMainPanel::getInstance()->GetImageDataSizeZ();//->getSceneManager()->GetImageDataSizeZ();
418 int ii,sizeLstContourThings;
419 for ( z=0 ; z<sizeZ ; z++)
422 std::vector<std::string> lstContourThings = interfMainPanel::getInstance()->getOutlinesName(z);
424 //this->_modelManager->getOutlinesAtInstant( &instant );
426 sizeLstContourThings = lstContourThings.size();
427 tempString.Printf(_T("%d - %d"),z, sizeLstContourThings);
428 _grid->SetRowLabelValue(z, tempString );
430 for (ii=0 ; ii<sizeLstContourThings ; ii++)
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 );
440 _grid->SetRowLabelValue(sizeZ, _T(" ") );
441 for (ii=0 ; ii<sizeLstContourThings ; ii++)
443 _grid->SetCellValue( sizeZ, ii, _T(" ") );
448 void interfInformationPanel::setStringInfoPanel(wxString tmpString){
449 _staticTextInformation->SetLabel(tmpString);
452 void interfInformationPanel::setRowLabelInfoPanel(int z,wxString tempString){
453 _grid->SetRowLabelValue(z, tempString );
456 int interfInformationPanel::getNumberCols(){
457 return _grid->GetNumberCols();
460 void interfInformationPanel::appendCols(int numcols){
461 _grid->AppendCols(numcols);
464 void interfInformationPanel::setCellValue(int z,int tmpIntA,wxString tempString){
465 _grid->SetCellValue( z, tmpIntA , tempString );
468 void interfInformationPanel::setColLabel(int tmpIntB,wxString tmpTitleString){
469 _grid->SetColLabelValue(tmpIntB, tmpTitleString);
472 wxString interfInformationPanel::getCellValue(int j,int i){
473 return _grid->GetCellValue( j , i );
476 void interfInformationPanel::onContourGroup(wxCommandEvent& event)
478 printf("EED interfInformationPanel::onContourGroup \n");
479 int contourGroup=_radiolstboxContourGroup->GetSelection();
484 interfMainPanel::getInstance()->SetContourGroup( _radiolstboxContourGroup->GetSelection() );
487 //CMRU 29-08-09-----------------------------------------------------------------------------------------------
488 interfCalibrationPanel:: interfCalibrationPanel(wxWindow * parent)
489 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN)
492 interfMainPanel::getInstance()->getImageRange(range);
498 options[2]=_T("inch");
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);
504 new wxStaticText(this, wxID_ANY, wxT("Real Size: "), wxPoint(2, 5));
507 _size = new wxTextCtrl(this, wxID_ANY, wxT(""), wxPoint(78,3), wxSize(70, 20), 0, wxDefaultValidator, wxTextCtrlNameStr);
510 new wxButton(this, 1, wxT("Calibrate"), wxPoint(78, 70), wxSize(70, 25), 0, wxDefaultValidator, wxT("button"));
512 //Conexion del boton con su respectivo manejador
513 Connect(1, wxEVT_COMMAND_BUTTON_CLICKED,(wxObjectEventFunction) &interfCalibrationPanel::onCalibrate);
517 interfCalibrationPanel:: ~interfCalibrationPanel()
521 void interfCalibrationPanel::onCalibrate(wxCommandEvent& event)
523 wxString size =_size->GetValue();
524 int unit = _unitsRadiobox->GetSelection();
525 interfMainPanel::getInstance()->onCalibration(size, unit);
527 //------------------------------------------------------------------------------------------------------------