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()->GetImageDataRange(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();
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);
26 _interpolationCheckBox = new wxCheckBox(this, -1, _T("Image interpolation") );
27 _interpolationCheckBox->SetValue(true);
29 Connect( _withOfContourLine->GetId() , wxEVT_SCROLL_CHANGED , (wxObjectEventFunction) &interfConfigurationPanel::onWidthOfContour );
30 Connect( _withOfContourLine->GetId() , wxEVT_SCROLL_THUMBTRACK , (wxObjectEventFunction) &interfConfigurationPanel::onWidthOfContour );
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 );
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 );
52 this->SetSizer( sizer );
54 //panel->SetSize( sizepanel );
56 this->SetAutoLayout( true );
62 interfConfigurationPanel::~interfConfigurationPanel()
66 void interfConfigurationPanel::onWidthOfContour(wxScrollEvent& event){
68 double width = (double)_withOfContourLine->GetValue() / 2.0;
69 interfMainPanel::getInstance()->onWidthOfContour(width);
72 void interfConfigurationPanel::onBrigthnessColorWindowLevel(wxScrollEvent& event){
73 int colorwindow = _brithtnessColorLevel->GetValue();
74 int windowlevel = _brithtnessWindowLevel->GetValue();
77 interfMainPanel::getInstance()->onBrigthnessColorWindowLevel(colorwindow, windowlevel);
81 void interfConfigurationPanel::OnInterpolation(wxCommandEvent& event)
84 interfMainPanel::getInstance()->onInterpolation(_interpolationCheckBox->GetValue());
90 ** Begin of the spread panel
93 interfSpreadPanel::interfSpreadPanel(wxWindow* parent)
94 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN)
97 //wxPanel *panel = new wxPanel(parent,-1);
99 //_contourPropagation = new ContourPropagation();
101 //wxPanel *panel = new wxPanel(parent,-1,wxDefaultPosition, wxDefaultSize,wxNO_BORDER, wxString("",wxConvUTF8));
103 wxButton *spreadResetBtn = new wxButton(this,-1,_T("Reset"),wxDefaultPosition, wxDefaultSize );
104 wxButton *spreadAddBtn = new wxButton(this,-1,_T("Add"),wxDefaultPosition, wxDefaultSize);
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);
113 wxButton *spreadGoBtn = new wxButton(this,-1,_T("Go"),wxDefaultPosition, wxDefaultSize);
114 _staticTextSpread = new wxStaticText(this,-1,_T(" "));
116 _wxtextctrlSpread = new wxTextCtrl(this,-1, _T(""),wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE );
117 _wxtextctrlSpread->SetEditable(false);
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 );
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 );
132 this->SetSizer( sizer );
133 //this->SetSize( wxDefaultSize );
134 this->SetAutoLayout( true );
139 interfSpreadPanel::~interfSpreadPanel(){
142 void interfSpreadPanel::onSpreadReset(wxCommandEvent& event){
143 setStringSpread(" ");
144 _wxtextctrlSpread->SetValue(wxString("",wxConvUTF8));
145 interfMainPanel::getInstance()->resetAppend();
147 void interfSpreadPanel::onSpreadAdd(wxCommandEvent& event){
148 interfMainPanel::getInstance()->onSpreadAdd();
150 void interfSpreadPanel::onSpreadGo(wxCommandEvent& event){
153 setStringSpread(" ");
154 int typeMethodFindCtrlPoints=_spreadMethodRadiobox->GetSelection();
156 interfMainPanel::getInstance()->onSpreadGo(typeMethodFindCtrlPoints);
160 void interfSpreadPanel::appendStringSpread(std::string val){
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);
170 void interfSpreadPanel::setStringSpread(std::string stringtemp){
172 wxString newstring(stringtemp.c_str(),wxConvUTF8);
173 //_wxtextctrlSpread->SetEditable(true);
174 _staticTextSpread->SetLabel(newstring);
175 //_wxtextctrlSpread->SetEditable(false);
179 ** Begin of information panel
181 interfInformationPanel::interfInformationPanel(wxWindow * parent)
182 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN){
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);
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);
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 );
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 );
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 );
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 );
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] );
244 _staticTextInformation = new wxStaticText(this,-1,_T(" "));
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 );
252 _grid = new wxGrid( this,
255 wxSize( 100, 100 ) );
257 int i,gridCol=10,gridRow=sizeZ;
258 _grid->CreateGrid( 0, 0 );
259 _grid->AppendRows(gridRow);
260 _grid->AppendCols(gridCol);
262 for (i=0;i<gridRow;i++)
264 _grid->SetRowLabelValue(i, _T(" ") );
266 // _grid->SetColLabelSize(0);
269 FillGridWithContoursInformation();
271 wxFlexGridSizer * sizerA = new wxFlexGridSizer(10);
272 sizerA->Add( _informationRadiobox , 1, wxALL ,2 );
273 sizerA->Add( _radiolstboxContourGroup , 1, wxALL ,2 );
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 );
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 );
294 this->SetSizer( sizer );
295 this->SetSize( wxSize(1500,1500) );
296 //this->SetBackgroundColour( wxColour(100,100,100) );
297 this->SetAutoLayout( true );
301 interfInformationPanel::~interfInformationPanel(){
304 void interfInformationPanel::onInformationContourLabels(wxCommandEvent& event){
306 FillGridWithContoursInformation();
308 void interfInformationPanel::onExtractInformation(wxCommandEvent& event){
312 int typeContourGroup = this->_radiolstboxContourGroup->GetSelection();
313 int selection = _informationRadiobox->GetSelection();
314 int minZ = _mbarrangeSliceInformation->GetStart();
315 int maxZ = _mbarrangeSliceInformation->GetEnd();
317 interfMainPanel::getInstance()->onInformationContourLabels(typeContourGroup, selection, minZ, maxZ);
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)
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);
334 void interfInformationPanel::FillGridWithContoursInformation(){
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 );
346 int z,sizeZ = interfMainPanel::getInstance()->GetImageDataSizeZ();//->getSceneManager()->GetImageDataSizeZ();
347 int ii,sizeLstContourThings;
348 for ( z=0 ; z<sizeZ ; z++)
351 std::vector<std::string> lstContourThings = interfMainPanel::getInstance()->getOutlinesName(z);
353 //this->_modelManager->getOutlinesAtInstant( &instant );
355 sizeLstContourThings = lstContourThings.size();
356 tempString.Printf(_T("%d - %d"),z, sizeLstContourThings);
357 _grid->SetRowLabelValue(z, tempString );
359 for (ii=0 ; ii<sizeLstContourThings ; ii++)
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 );
369 void interfInformationPanel::setStringInfoPanel(wxString tmpString){
370 _staticTextInformation->SetLabel(tmpString);
373 void interfInformationPanel::setRowLabelInfoPanel(int z,wxString tempString){
374 _grid->SetRowLabelValue(z, tempString );
377 int interfInformationPanel::getNumberCols(){
378 return _grid->GetNumberCols();
381 void interfInformationPanel::appendCols(int numcols){
382 _grid->AppendCols(numcols);
385 void interfInformationPanel::setCellValue(int z,int tmpIntA,wxString tempString){
386 _grid->SetCellValue( z, tmpIntA , tempString );
389 void interfInformationPanel::setColLabel(int tmpIntB,wxString tmpTitleString){
390 _grid->SetColLabelValue(tmpIntB, tmpTitleString);
393 wxString interfInformationPanel::getCellValue(int j,int i){
394 return _grid->GetCellValue( j , i );
400 ** Begin of the mirror panel
403 interfMirrorPanel::interfMirrorPanel(wxWindow* parent)
404 : wxPanel(parent, -1, wxDefaultPosition, wxDefaultSize, wxBORDER_SUNKEN)
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);
409 Connect( mirrorGoBtn->GetId(), wxEVT_COMMAND_BUTTON_CLICKED , (wxObjectEventFunction) &interfMirrorPanel::onMirrorGo );
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 );
416 this->SetSizer( sizer );
417 this->SetAutoLayout( true );
421 interfMirrorPanel::~interfMirrorPanel(){
424 void interfMirrorPanel::onMirrorGo(wxCommandEvent& event)
426 //wxString thick=_thickness->GetValue();
427 interfMainPanel::getInstance()->onMirror();