1 /*=========================================================================
4 Module: $RCSfile: wxMaracas_ViewerWidget.cxx,v $
6 Date: $Date: 2012/11/14 07:30:52 $
7 Version: $Revision: 1.37 $
9 Copyright: (c) 2002, 2003
12 This software is distributed WITHOUT ANY WARRANTY; without even
13 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
14 PURPOSE. See the above copyright notice for more information.
16 =========================================================================*/
18 //------------------------------------------------------------------------------------------------------------
19 // Definition includes
20 //------------------------------------------------------------------------------------------------------------
21 #include "wxMaracas_ViewerWidget.h"
22 #include <wx/notebook.h>
23 //------------------------------------------------------------------------------------------------------------
25 //------------------------------------------------------------------------------------------------------------
26 //------------------------------------------------------------------------------------------------------------
27 // Constructors & Destructors
28 //------------------------------------------------------------------------------------------------------------
30 wxMaracas_ViewerWidget::wxMaracas_ViewerWidget(wxWindow *parent, vtkImageData* imagedata, int type, vtkMPRBaseData *vtkmprbasedata)
31 : wxPanel( parent, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL)
33 wxPanel *panel = this;
34 wxWindow *wxwindow = NULL, *window3D = 0;
35 wxSplitterWindow *panelClipping3D= 0;
36 // wxPanel *panelControl = 0;
37 // wxFlexGridSizer *sizerCtrol = 0;
38 wxPanel *controlPanelMPR3D = 0;
39 wxPanel *controlPanelClippingSurf3D = 0;
40 //RaC 03-2010 Adding a tab
41 wxPanel *controlPanelClippingVol3D = 0;
43 wxBoxSizer *sizer = 0;
47 if (vtkmprbasedata==NULL)
49 minternalVtkmprbasedata = true;
50 mvtkmprbasedata = new vtkMPRBaseData();
51 marImageData *marimagedata = new marImageData( imagedata );
52 mvtkmprbasedata->SetMarImageData(marimagedata);
54 minternalVtkmprbasedata = false;
55 mvtkmprbasedata = vtkmprbasedata;
58 mvtk2Dbaseview = NULL;
59 mvtkmpr2Dview_X = NULL;
60 mvtkmpr2Dview_Y = NULL;
61 mvtkmpr2Dview_Z = NULL;
62 mvtkplane2Dview = NULL;
65 mwxvtkclipping3Dview = NULL;
66 mwxvtk3Dbaseview_Clipping3D = NULL;
67 mwxvtkmpr3Dview = NULL;
68 vtkmpr3Ddataviewer = NULL;
72 mvtk2Dbaseview = new wxVtk2DBaseView(panel);
73 mvtk2Dbaseview->SetVtkBaseData(mvtkmprbasedata);
74 wxwindow = mvtk2Dbaseview->GetWxVTKRenderWindowInteractor();
77 mvtkmpr2Dview_Z = new wxVtkMPR2DView(panel,2);
78 mvtkmpr2Dview_Z->SetVtkBaseData(mvtkmprbasedata);
79 wxwindow = mvtkmpr2Dview_Z->GetWxVTKRenderWindowInteractor();
82 mvtkmpr2Dview_X = new wxVtkMPR2DView(panel,0);
83 mvtkmpr2Dview_X->SetVtkBaseData(mvtkmprbasedata);
84 wxwindow = mvtkmpr2Dview_X->GetWxVTKRenderWindowInteractor();
87 mvtkmpr2Dview_Y = new wxVtkMPR2DView(panel,1);
88 mvtkmpr2Dview_Y->SetVtkBaseData(mvtkmprbasedata);
89 wxwindow = mvtkmpr2Dview_Y->GetWxVTKRenderWindowInteractor();
92 mwidgetMesure = new wxWidgetMesure2D_Plane_in_MPR(panel);
93 mvtkplane2Dview = new vtkPlane2DView( mwidgetMesure->GetWindow2());
94 mwidgetMesure -> SetVtkPlane2DView( mvtkplane2Dview );
95 mvtkplane2Dview -> SetImgSize( 200 );
96 mvtkplane2Dview -> SetVtkBaseData(mvtkmprbasedata);
97 wxwindow = mwidgetMesure;
100 mwxsphereview = new wxSphereView( panel , mvtkmprbasedata, mvtkmprbasedata->GetImageData() );
101 wxwindow=mwxsphereview->GetWxVTKRenderWindowInteractor();
104 panelClipping3D = new wxSplitterWindow( panel , -1);
105 mwxvtk3Dbaseview_Clipping3D = new wxVtk3DBaseView( panelClipping3D );
107 mwxvtkclipping3Dview = new wxVtkClipping3DView(mwxvtk3Dbaseview_Clipping3D);
108 vtkClipping3DDataViewer *vtkclipping3Ddataviewer = new vtkClipping3DDataViewer();
109 vtkclipping3Ddataviewer->SetVtkMPRBaseData(mvtkmprbasedata);
110 vtkclipping3Ddataviewer->Configure();
111 mwxvtkclipping3Dview->SetVtkClipping3DDataViewer(vtkclipping3Ddataviewer);
113 mwxvtkmpr3Dview = new wxVtkMPR3DView( mwxvtk3Dbaseview_Clipping3D );
114 vtkMPR3DDataViewer *vtkmpr3Ddataviewer = new vtkMPR3DDataViewer();
115 vtkmpr3Ddataviewer->SetVtkMPRBaseData(mvtkmprbasedata);
116 vtkmpr3Ddataviewer->Configure();
117 mwxvtkmpr3Dview->SetVtkMPR3DDataViewer(vtkmpr3Ddataviewer);
119 window3D = mwxvtk3Dbaseview_Clipping3D->GetWxVTKRenderWindowInteractor();
122 wxNotebook *notebook = new wxNotebook(panelClipping3D, -1);
125 controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(notebook, true);
126 notebook->AddPage(controlPanelMPR3D, _T("Planes") );
129 controlPanelClippingSurf3D = mwxvtkclipping3Dview->CreateSurfControlPanel(notebook);
130 notebook->AddPage(controlPanelClippingSurf3D, _T("Surface") );
133 //RaC 03-2010 Moving the volume functionnality to other tab. The changes were realized only in the wxVtkClipping3DViewCntrlPanel class
134 controlPanelClippingVol3D = mwxvtkclipping3Dview->CreateVolControlPanel(notebook);
135 notebook->AddPage(controlPanelClippingVol3D, _T("Volume") );
137 panelClipping3D->SplitHorizontally( notebook , window3D , 10 );
138 //panelClipping3D->SetMinimumPaneSize( 15 );
139 panelClipping3D->SetMinimumPaneSize( 70 ); // JPR
141 /* EED 04 / Febrary / 2010
142 panelControl = new wxPanel(panelClipping3D,-1);
143 controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(panelControl, false);
144 controlPanelClipping3D = mwxvtkclipping3Dview->CreateControlPanel(panelControl);
145 // mbtnCutImageData = new wxCheckBox(panelControl,-1,_T("Cut Module"));
146 // Connect(_btnCutImageData->GetId() , wxEVT_COMMAND_CHECKBOX_CLICKED , (wxObjectEventFunction) &wxMPRWidget::OnCutImagaData );
147 sizerCtrol = new wxFlexGridSizer(1);
148 sizerCtrol->Add(controlPanelMPR3D , 1, wxALL|wxEXPAND, 2);
149 sizerCtrol->Add(controlPanelClipping3D , 1, wxALL|wxEXPAND, 2);
150 // sizerCtrol->Add( mbtnCutImageData , 1, wxALL, 2);
151 panelControl->SetAutoLayout(true);
152 panelControl->SetSizer(sizerCtrol);
153 panelControl->SetSize(400,350);
154 panelControl->Layout();
155 panelClipping3D -> SplitHorizontally( panelControl , window3D , 10 );
156 panelClipping3D -> SetMinimumPaneSize( 5 );
158 wxwindow=panelClipping3D;
160 } else if (type==6) {
161 panelClipping3D = new wxSplitterWindow( panel , -1);
162 mwxvtk3Dbaseview_Clipping3D = new wxVtk3DBaseView( panelClipping3D );
164 mwxvtkmpr3Dview = new wxVtkMPR3DView( mwxvtk3Dbaseview_Clipping3D );
166 vtkmpr3Ddataviewer = new vtkMPR3DDataViewer();
168 wxWindow *window3D = mwxvtk3Dbaseview_Clipping3D->GetWxVTKRenderWindowInteractor();
170 wxPanel *panelControl = new wxPanel(panelClipping3D,-1);
171 wxPanel *controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(panelControl, true);
173 wxFlexGridSizer *sizerCtrol = new wxFlexGridSizer(1);
174 sizerCtrol->Add(controlPanelMPR3D, 1, wxALL|wxEXPAND, 2);
176 panelControl->SetAutoLayout(true);
177 panelControl->SetSizer(sizerCtrol);
178 panelControl->SetSize(400,350);
179 panelControl->Layout();
180 //panelClipping3D->SetMinimumPaneSize( 5 );
181 panelClipping3D->SetMinimumPaneSize( 130 ); // FCY
182 panelClipping3D->SplitHorizontally( panelControl , window3D , 0 );
183 //panelClipping3D->SetSashSize(10);
184 panelClipping3D->UpdateSize(); //FCY
185 wxwindow=panelClipping3D;
187 vtkmpr3Ddataviewer->SetVtkMPRBaseData(mvtkmprbasedata);
188 //vtkmpr3Ddataviewer->Configure();
190 mwxvtkmpr3Dview->SetVtkMPR3DDataViewer(vtkmpr3Ddataviewer);
194 mwxvtk3Dbaseview_Clipping3D = new wxVtk3DBaseView( panel );
195 wxwindow = (wxWindow*) mwxvtk3Dbaseview_Clipping3D->GetWxVTKRenderWindowInteractor();
198 sizer = new wxBoxSizer(wxVERTICAL);
199 sizer->Add( wxwindow, 1, wxGROW);
200 panel->SetSizer(sizer);
201 panel->SetAutoLayout(true);
206 // mbbtkViewerMaracas= NULL;
208 //-------------------------------------------------------------------------
210 wxMaracas_ViewerWidget::~wxMaracas_ViewerWidget()
212 if (minternalVtkmprbasedata==true)
214 if (mvtkmprbasedata) { delete mvtkmprbasedata;}
217 if (mvtk2Dbaseview) { delete mvtk2Dbaseview; }
218 if (mvtkmpr2Dview_X) { delete mvtkmpr2Dview_X;}
219 if (mvtkmpr2Dview_Y) { delete mvtkmpr2Dview_Y;}
220 if (mvtkmpr2Dview_Z) { delete mvtkmpr2Dview_Z;}
221 if (mwidgetMesure) { delete mwidgetMesure; }
222 if (mvtkplane2Dview) { delete mvtkplane2Dview;}
223 if (mwxsphereview) { delete mwxsphereview; }
224 if (mwxvtkmpr3Dview) { delete mwxvtkmpr3Dview;}
225 if (mwxvtkclipping3Dview) { delete mwxvtkclipping3Dview;}
226 if (mwxvtk3Dbaseview_Clipping3D){ delete mwxvtk3Dbaseview_Clipping3D; mwxvtk3Dbaseview_Clipping3D=NULL;}
227 if (vtkmpr3Ddataviewer) { delete vtkmpr3Ddataviewer;}
229 //------------------------------------------------------------------------------------------------------------
231 //------------------------------------------------------------------------------------------------------------
233 //-------------------------------------------------------------------------
235 void wxMaracas_ViewerWidget::ConfigureVTK()
247 int ext[] = {0, 0, 0, 0, 0, 0}; //JPR
249 /*double org[3],spc[3];
257 double org[]={0.0, 0.0, 0.0}; //JPR
258 double spc[]={0.0, 0.0, 0.0}; //JPR
259 if (mvtkmprbasedata!=NULL)
261 mvtkmprbasedata->Configure();
263 if(mvtkmprbasedata->GetImageData() != NULL)
265 mvtkmprbasedata->GetImageData()->GetExtent(ext);
266 mvtkmprbasedata->GetImageData()->GetOrigin(org);
267 mvtkmprbasedata->GetImageData()->GetSpacing(spc);
269 x = (ext[0]+ext[1])/2;
270 y = (ext[2]+ext[3])/2;
271 z = (ext[4]+ext[5])/2;
273 mvtkmprbasedata->SetX( x );
274 mvtkmprbasedata->SetY( y );
275 mvtkmprbasedata->SetZ( z );
279 mvtkmprbasedata->SetX( 0 );
280 mvtkmprbasedata->SetY( 0 );
281 mvtkmprbasedata->SetZ( 0 );
285 if ( mvtk2Dbaseview !=NULL ) { mvtk2Dbaseview->Configure(); }
286 if ( mvtkmpr2Dview_X !=NULL ) { mvtkmpr2Dview_X->Configure(); }
287 if ( mvtkmpr2Dview_Y !=NULL ) { mvtkmpr2Dview_Y->Configure(); }
288 if ( mvtkmpr2Dview_Z !=NULL ) { mvtkmpr2Dview_Z->Configure(); }
289 if ( mvtkplane2Dview !=NULL ) { mvtkplane2Dview->Configure(); }
290 if ( mwidgetMesure !=NULL ) { mwidgetMesure->ConfigureA(mvtkplane2Dview); }
291 if ( mwidgetMesure !=NULL ) { mwidgetMesure->ConfigureA(mvtkplane2Dview); }
292 if ( mwidgetMesure !=NULL ) { mwidgetMesure->SetActiveLink(true); }
293 if ( mwidgetMesure !=NULL ) { mwidgetMesure->SetMesureScale( 1 ); }
294 if ( mwxsphereview !=NULL ) { mwxsphereview->Configure(); }
297 if (mwxvtk3Dbaseview_Clipping3D !=NULL)
299 mwxvtk3Dbaseview_Clipping3D->Configure();
302 if (vtkmpr3Ddataviewer !=NULL)
304 vtkmpr3Ddataviewer->Configure();
308 if (mwxvtkmpr3Dview !=NULL)
310 mwxvtkmpr3Dview->Configure();
311 //EED??? mwxvtkmpr3Dview->ResetCamera(ext,org,spc);
314 if (mwxvtkclipping3Dview !=NULL)
316 mwxvtkclipping3Dview->Configure();
319 //if(vtkmpr3Ddataviewer!=NULL){vtkmpr3Ddataviewer->Configure();}
322 //if (mwxvtkmpr3Dview !=NULL) {
323 // mwxvtkmpr3Dview->ResetCamera();
328 //-------------------------------------------------------------------------
329 void wxMaracas_ViewerWidget::Refresh(bool eraseBackground ,const wxRect* rect ) // virtual eraseBackground=true , rect=NULL
331 wxPanel::Refresh(false);
334 //-------------------------------------------------------------------------
335 void wxMaracas_ViewerWidget::RefreshView()
337 if (mvtk2Dbaseview !=NULL ){ mvtk2Dbaseview->Refresh(); }
338 if (mvtkmpr2Dview_X !=NULL ){ mvtkmpr2Dview_X->Refresh(); }
339 if (mvtkmpr2Dview_Y !=NULL ){ mvtkmpr2Dview_Y->Refresh(); }
340 if (mvtkmpr2Dview_Z !=NULL ){ mvtkmpr2Dview_Z->Refresh(); }
341 if (mvtkplane2Dview !=NULL ){ mvtkplane2Dview->Refresh(); }
342 if (mwxsphereview !=NULL ){ mwxsphereview ->Refresh(); }
343 if (mwxvtkmpr3Dview !=NULL ){ mwxvtkmpr3Dview->RefreshView(); }
344 if (mwxvtkclipping3Dview !=NULL ){ mwxvtkclipping3Dview->Refresh(); }
345 if (mwxvtk3Dbaseview_Clipping3D !=NULL ){ mwxvtk3Dbaseview_Clipping3D->Refresh(); }
348 //-------------------------------------------------------------------------
350 wxVtkBaseView *wxMaracas_ViewerWidget::GetwxVtkBaseView()
352 wxVtkBaseView *wxvtkbaseview=NULL;
353 if (mvtk2Dbaseview!=NULL){
354 wxvtkbaseview = mvtk2Dbaseview;
356 if (mvtkmpr2Dview_X!=NULL){
357 wxvtkbaseview = mvtkmpr2Dview_X;
359 if (mvtkmpr2Dview_Y!=NULL){
360 wxvtkbaseview = mvtkmpr2Dview_Y;
362 if (mvtkmpr2Dview_Z!=NULL){
363 wxvtkbaseview = mvtkmpr2Dview_Z;
365 if (mvtkplane2Dview!=NULL){
366 wxvtkbaseview = mvtkplane2Dview;
368 if (mwxsphereview!=NULL){
369 wxvtkbaseview = mwxsphereview;
371 if (mwxvtk3Dbaseview_Clipping3D!=NULL){
372 wxvtkbaseview = mwxvtk3Dbaseview_Clipping3D;
374 return wxvtkbaseview ;
377 void wxMaracas_ViewerWidget::SetImage( vtkImageData *image )
379 if(mvtkmprbasedata !=NULL)
381 marImageData* mar = mvtkmprbasedata->GetMarImageData();
382 mar->removeImageData(0);
383 mar->AddImageData(image);
387 if (mvtk2Dbaseview!=NULL)
389 mvtk2Dbaseview->SetImageToVtkViewer(image);
392 if (mvtkmpr2Dview_X!=NULL){
393 mvtkmpr2Dview_X->SetImageToVtkViewer(image);
395 if (mvtkmpr2Dview_Y!=NULL){
396 mvtkmpr2Dview_Y->SetImageToVtkViewer(image);
398 if (mvtkmpr2Dview_Z!=NULL){
399 mvtkmpr2Dview_Z->SetImageToVtkViewer(image);
402 if (mvtkplane2Dview!=NULL){
403 // ??? EED 10 oct 2012
405 if (mwxsphereview!=NULL){
406 // ??? EED 10 oct 2012
408 if (mwxvtk3Dbaseview_Clipping3D!=NULL){
409 // ??? EED 10 oct 2012
419 double wxMaracas_ViewerWidget :: GetX()
422 if(mvtkmprbasedata !=NULL)
424 value = mvtkmprbasedata->GetX();
429 double wxMaracas_ViewerWidget::GetY()
432 if(mvtkmprbasedata !=NULL)
434 value = mvtkmprbasedata->GetY();
439 double wxMaracas_ViewerWidget::GetZ()
442 if(mvtkmprbasedata !=NULL)
444 value = mvtkmprbasedata->GetZ();
447 // return mvtk2Dbaseview->GetVtkBaseData()->GetZ();
450 //-------------------------------------------------------------------------------------------
451 void wxMaracas_ViewerWidget::setColorTransferFunction(vtkColorTransferFunction* colortable)
453 if(mvtkmpr2Dview_X!=NULL)
455 mvtkmpr2Dview_X->setColorTransferFunction(colortable);
458 if(mvtkmpr2Dview_Y!=NULL)
460 mvtkmpr2Dview_Y->setColorTransferFunction(colortable);
463 if(mvtkmpr2Dview_Z!=NULL)
465 mvtkmpr2Dview_Z->setColorTransferFunction(colortable);
468 if(mwxvtkmpr3Dview!=NULL)
470 mwxvtkmpr3Dview->setColorTransferFunction(colortable);
474 //-------------------------------------------------------------------------------------------
475 void wxMaracas_ViewerWidget::SetColorWindowLevel(double colorWindow, double colorLevel)
477 mvtkmprbasedata->SetColorWindow(colorWindow);
478 mvtkmprbasedata->SetColorLevel(colorLevel);
482 if(mvtk2Dbaseview!=NULL)
484 mvtk2Dbaseview->SetColorWindow(level);
487 if(mvtkmpr2Dview_X!=NULL)
489 mvtkmpr2Dview_X->SetColorWindow(level);
492 if(mvtkmpr2Dview_Y!=NULL)
494 mvtkmpr2Dview_Y->SetColorWindow(level);
497 if(mvtkmpr2Dview_Z!=NULL)
499 mvtkmpr2Dview_Z->SetColorWindow(level);
502 if(mwxvtkmpr3Dview!=NULL)
504 mwxvtkmpr3Dview->SetColorWindow(level);