1 /*# ---------------------------------------------------------------------
3 # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
5 # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
6 # Previous Authors : Laurent Guigues, Jean-Pierre Roux
7 # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
9 # This software is governed by the CeCILL-B license under French law and
10 # abiding by the rules of distribution of free software. You can use,
11 # modify and/ or redistribute the software under the terms of the CeCILL-B
12 # license as circulated by CEA, CNRS and INRIA at the following URL
13 # http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
14 # or in the file LICENSE.txt.
16 # As a counterpart to the access to the source code and rights to copy,
17 # modify and redistribute granted by the license, users are provided only
18 # with a limited warranty and the software's author, the holder of the
19 # economic rights, and the successive licensors have only limited
22 # The fact that you are presently reading this means that you have had
23 # knowledge of the CeCILL-B license and that you accept its terms.
24 # ------------------------------------------------------------------------ */
26 /*=========================================================================
29 Module: $RCSfile: wxMaracas_ViewerWidget.cxx,v $
31 Date: $Date: 2012/11/15 14:14:35 $
32 Version: $Revision: 1.38 $
34 Copyright: (c) 2002, 2003
37 This software is distributed WITHOUT ANY WARRANTY; without even
38 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
39 PURPOSE. See the above copyright notice for more information.
41 =========================================================================*/
43 //------------------------------------------------------------------------------------------------------------
44 // Definition includes
45 //------------------------------------------------------------------------------------------------------------
46 #include "wxMaracas_ViewerWidget.h"
47 #include <wx/notebook.h>
48 //------------------------------------------------------------------------------------------------------------
50 //------------------------------------------------------------------------------------------------------------
51 //------------------------------------------------------------------------------------------------------------
52 // Constructors & Destructors
53 //------------------------------------------------------------------------------------------------------------
55 wxMaracas_ViewerWidget::wxMaracas_ViewerWidget(wxWindow *parent, vtkImageData* imagedata, int type, vtkMPRBaseData *vtkmprbasedata)
56 : wxPanel( parent, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL)
58 wxPanel *panel = this;
59 wxWindow *wxwindow = NULL;
60 wxWindow *window3D = NULL;
61 wxSplitterWindow *panelClipping3D = NULL;
62 // wxPanel *panelControl = NULL;
63 // wxFlexGridSizer *sizerCtrol = NULL;
64 wxPanel *controlPanelMPR3D = NULL;
65 wxPanel *controlPanelClippingSurf3D = NULL;
66 //RaC 03-2010 Adding a tab
67 wxPanel *controlPanelClippingVol3D = NULL;
69 wxBoxSizer *sizer = 0;
73 if (vtkmprbasedata==NULL)
75 minternalVtkmprbasedata = true;
76 mvtkmprbasedata = new vtkMPRBaseData();
77 marImageData *marimagedata = new marImageData( imagedata );
78 mvtkmprbasedata->SetMarImageData(marimagedata);
80 minternalVtkmprbasedata = false;
81 mvtkmprbasedata = vtkmprbasedata;
84 mvtk2Dbaseview = NULL;
85 mvtkmpr2Dview_X = NULL;
86 mvtkmpr2Dview_Y = NULL;
87 mvtkmpr2Dview_Z = NULL;
88 mvtkplane2Dview = NULL;
91 mwxvtkclipping3Dview = NULL;
92 mwxvtk3Dbaseview_Clipping3D = NULL;
93 mwxvtkmpr3Dview = NULL;
94 vtkmpr3Ddataviewer = NULL;
98 mvtk2Dbaseview = new wxVtk2DBaseView(panel);
99 mvtk2Dbaseview->SetVtkBaseData(mvtkmprbasedata);
100 wxwindow = mvtk2Dbaseview->GetWxVTKRenderWindowInteractor();
103 mvtkmpr2Dview_Z = new wxVtkMPR2DView(panel,2);
104 mvtkmpr2Dview_Z->SetVtkBaseData(mvtkmprbasedata);
105 wxwindow = mvtkmpr2Dview_Z->GetWxVTKRenderWindowInteractor();
108 mvtkmpr2Dview_X = new wxVtkMPR2DView(panel,0);
109 mvtkmpr2Dview_X->SetVtkBaseData(mvtkmprbasedata);
110 wxwindow = mvtkmpr2Dview_X->GetWxVTKRenderWindowInteractor();
113 mvtkmpr2Dview_Y = new wxVtkMPR2DView(panel,1);
114 mvtkmpr2Dview_Y->SetVtkBaseData(mvtkmprbasedata);
115 wxwindow = mvtkmpr2Dview_Y->GetWxVTKRenderWindowInteractor();
118 mwidgetMesure = new wxWidgetMesure2D_Plane_in_MPR(panel);
119 mvtkplane2Dview = new vtkPlane2DView( mwidgetMesure->GetWindow2());
120 mwidgetMesure -> SetVtkPlane2DView( mvtkplane2Dview );
121 mvtkplane2Dview -> SetImgSize( 200 );
122 mvtkplane2Dview -> SetVtkBaseData(mvtkmprbasedata);
123 wxwindow = mwidgetMesure;
127 // mwxsphereview = new wxSphereView( panel , mvtkmprbasedata , mvtkmprbasedata->GetImageData() );
128 mwxsphereview = new wxSphereView( panel , mvtkmprbasedata );
129 wxwindow=mwxsphereview->GetWxVTKRenderWindowInteractor();
132 panelClipping3D = new wxSplitterWindow( panel , -1);
133 mwxvtk3Dbaseview_Clipping3D = new wxVtk3DBaseView( panelClipping3D , vtkmprbasedata);
134 mwxvtkclipping3Dview = new wxVtkClipping3DView(mwxvtk3Dbaseview_Clipping3D);
135 vtkClipping3DDataViewer *vtkclipping3Ddataviewer= new vtkClipping3DDataViewer();
136 vtkclipping3Ddataviewer->SetVtkMPRBaseData(mvtkmprbasedata);
137 vtkclipping3Ddataviewer->Configure();
138 mwxvtkclipping3Dview->SetVtkClipping3DDataViewer(vtkclipping3Ddataviewer);
140 mwxvtkmpr3Dview = new wxVtkMPR3DView( mwxvtk3Dbaseview_Clipping3D );
141 vtkMPR3DDataViewer *vtkmpr3Ddataviewer = new vtkMPR3DDataViewer();
142 vtkmpr3Ddataviewer->SetVtkMPRBaseData(mvtkmprbasedata);
143 vtkmpr3Ddataviewer->Configure();
144 mwxvtkmpr3Dview->SetVtkMPR3DDataViewer(vtkmpr3Ddataviewer);
146 window3D = mwxvtk3Dbaseview_Clipping3D->GetWxVTKRenderWindowInteractor();
149 wxNotebook *notebook = new wxNotebook(panelClipping3D, -1);
152 controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(notebook, true);
153 notebook->AddPage(controlPanelMPR3D, _T("Planes") );
156 controlPanelClippingSurf3D = mwxvtkclipping3Dview->CreateSurfControlPanel(notebook);
157 notebook->AddPage(controlPanelClippingSurf3D, _T("Surface") );
160 //RaC 03-2010 Moving the volume functionnality to other tab. The changes were realized only in the wxVtkClipping3DViewCntrlPanel class
161 controlPanelClippingVol3D = mwxvtkclipping3Dview->CreateVolControlPanel(notebook);
162 notebook->AddPage(controlPanelClippingVol3D, _T("Volume") );
164 panelClipping3D->SplitHorizontally( notebook , window3D , 10 );
165 //panelClipping3D->SetMinimumPaneSize( 15 );
166 panelClipping3D->SetMinimumPaneSize( 70 ); // JPR
167 //RaC Nov2012 Correctly resize internal panels with the window resize event
168 panelClipping3D->SetSashGravity(0.5);
170 /* EED 04 / Febrary / 2010
171 panelControl = new wxPanel(panelClipping3D,-1);
172 controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(panelControl, false);
173 controlPanelClipping3D = mwxvtkclipping3Dview->CreateControlPanel(panelControl);
174 // mbtnCutImageData = new wxCheckBox(panelControl,-1,_T("Cut Module"));
175 // Connect(_btnCutImageData->GetId() , wxEVT_COMMAND_CHECKBOX_CLICKED , (wxObjectEventFunction) &wxMPRWidget::OnCutImagaData );
176 sizerCtrol = new wxFlexGridSizer(1);
177 sizerCtrol->Add(controlPanelMPR3D , 1, wxALL|wxEXPAND, 2);
178 sizerCtrol->Add(controlPanelClipping3D , 1, wxALL|wxEXPAND, 2);
179 // sizerCtrol->Add( mbtnCutImageData , 1, wxALL, 2);
180 panelControl->SetAutoLayout(true);
181 panelControl->SetSizer(sizerCtrol);
182 panelControl->SetSize(400,350);
183 panelControl->Layout();
184 panelClipping3D -> SplitHorizontally( panelControl , window3D , 10 );
185 panelClipping3D -> SetMinimumPaneSize( 5 );
187 wxwindow=panelClipping3D;
189 } else if (type==6) {
190 panelClipping3D = new wxSplitterWindow( panel , -1);
191 mwxvtk3Dbaseview_Clipping3D = new wxVtk3DBaseView( panelClipping3D , vtkmprbasedata);
192 mwxvtkmpr3Dview = new wxVtkMPR3DView( mwxvtk3Dbaseview_Clipping3D );
193 vtkmpr3Ddataviewer = new vtkMPR3DDataViewer();
194 wxWindow *window3D = mwxvtk3Dbaseview_Clipping3D->GetWxVTKRenderWindowInteractor();
195 wxPanel *panelControl = new wxPanel(panelClipping3D,-1);
196 wxPanel *controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(panelControl, true);
197 wxFlexGridSizer *sizerCtrol = new wxFlexGridSizer(1);
198 sizerCtrol->Add(controlPanelMPR3D, 1, wxALL|wxEXPAND, 2);
200 panelControl->SetAutoLayout(true);
201 panelControl->SetSizer(sizerCtrol);
202 panelControl->SetSize(400,350);
203 panelControl->Layout();
204 //panelClipping3D->SetMinimumPaneSize( 5 );
205 panelClipping3D->SetMinimumPaneSize( 130 ); // FCY
206 panelClipping3D->SplitHorizontally( panelControl , window3D , 0 );
207 //panelClipping3D->SetSashSize(10);
209 //RaC Nov2012 Correctly resize internal panels with the window resize event
210 panelClipping3D->SetSashGravity(0.5);
211 panelClipping3D->UpdateSize(); //FCY
212 wxwindow=panelClipping3D;
214 vtkmpr3Ddataviewer->SetVtkMPRBaseData(mvtkmprbasedata);
215 //vtkmpr3Ddataviewer->Configure();
217 mwxvtkmpr3Dview->SetVtkMPR3DDataViewer(vtkmpr3Ddataviewer);
221 mwxvtk3Dbaseview_Clipping3D = new wxVtk3DBaseView( panel ,vtkmprbasedata);
222 wxwindow = (wxWindow*) mwxvtk3Dbaseview_Clipping3D->GetWxVTKRenderWindowInteractor();
225 sizer = new wxBoxSizer(wxVERTICAL);
226 sizer->Add( wxwindow, 1, wxGROW);
227 panel->SetSizer(sizer);
228 panel->SetAutoLayout(true);
233 // mbbtkViewerMaracas= NULL;
235 //-------------------------------------------------------------------------
237 wxMaracas_ViewerWidget::~wxMaracas_ViewerWidget()
239 if (minternalVtkmprbasedata==true)
241 if (mvtkmprbasedata) { delete mvtkmprbasedata;}
244 if (mvtk2Dbaseview) { delete mvtk2Dbaseview; }
245 if (mvtkmpr2Dview_X) { delete mvtkmpr2Dview_X;}
246 if (mvtkmpr2Dview_Y) { delete mvtkmpr2Dview_Y;}
247 if (mvtkmpr2Dview_Z) { delete mvtkmpr2Dview_Z;}
248 if (mwidgetMesure) { delete mwidgetMesure; }
249 if (mvtkplane2Dview) { delete mvtkplane2Dview;}
250 if (mwxsphereview) { delete mwxsphereview; }
251 if (mwxvtkmpr3Dview) { delete mwxvtkmpr3Dview;}
252 if (mwxvtkclipping3Dview) { delete mwxvtkclipping3Dview;}
253 if (mwxvtk3Dbaseview_Clipping3D){ delete mwxvtk3Dbaseview_Clipping3D; mwxvtk3Dbaseview_Clipping3D=NULL;}
254 if (vtkmpr3Ddataviewer) { delete vtkmpr3Ddataviewer;}
256 //------------------------------------------------------------------------------------------------------------
258 //------------------------------------------------------------------------------------------------------------
260 //-------------------------------------------------------------------------
262 void wxMaracas_ViewerWidget::ConfigureVTK()
274 int ext[] = {0, 0, 0, 0, 0, 0}; //JPR
276 /*double org[3],spc[3];
284 double org[]={0.0, 0.0, 0.0}; //JPR
285 double spc[]={0.0, 0.0, 0.0}; //JPR
286 if (mvtkmprbasedata!=NULL)
288 mvtkmprbasedata->Configure();
290 if(mvtkmprbasedata->GetImageData() != NULL)
292 mvtkmprbasedata->GetImageData()->GetExtent(ext);
293 mvtkmprbasedata->GetImageData()->GetOrigin(org);
294 mvtkmprbasedata->GetImageData()->GetSpacing(spc);
296 x = (ext[0]+ext[1])/2;
297 y = (ext[2]+ext[3])/2;
298 z = (ext[4]+ext[5])/2;
300 mvtkmprbasedata->SetX( x );
301 mvtkmprbasedata->SetY( y );
302 mvtkmprbasedata->SetZ( z );
306 mvtkmprbasedata->SetX( 0 );
307 mvtkmprbasedata->SetY( 0 );
308 mvtkmprbasedata->SetZ( 0 );
312 if ( mvtk2Dbaseview !=NULL ) { mvtk2Dbaseview->Configure(); }
313 if ( mvtkmpr2Dview_X !=NULL ) { mvtkmpr2Dview_X->Configure(); }
314 if ( mvtkmpr2Dview_Y !=NULL ) { mvtkmpr2Dview_Y->Configure(); }
315 if ( mvtkmpr2Dview_Z !=NULL ) { mvtkmpr2Dview_Z->Configure(); }
316 if ( mvtkplane2Dview !=NULL ) { mvtkplane2Dview->Configure(); }
317 if ( mwidgetMesure !=NULL ) { mwidgetMesure->ConfigureA(mvtkplane2Dview); }
318 if ( mwidgetMesure !=NULL ) { mwidgetMesure->ConfigureA(mvtkplane2Dview); }
319 if ( mwidgetMesure !=NULL ) { mwidgetMesure->SetActiveLink(true); }
320 if ( mwxsphereview !=NULL ) { mwxsphereview->Configure(); }
323 if (mwxvtk3Dbaseview_Clipping3D !=NULL)
325 mwxvtk3Dbaseview_Clipping3D->Configure();
328 if (vtkmpr3Ddataviewer !=NULL)
330 vtkmpr3Ddataviewer->Configure();
334 if (mwxvtkmpr3Dview !=NULL)
336 mwxvtkmpr3Dview->Configure();
337 //EED??? mwxvtkmpr3Dview->ResetCamera(ext,org,spc);
340 if (mwxvtkclipping3Dview !=NULL)
342 mwxvtkclipping3Dview->Configure();
345 //if(vtkmpr3Ddataviewer!=NULL){vtkmpr3Ddataviewer->Configure();}
348 //if (mwxvtkmpr3Dview !=NULL) {
349 // mwxvtkmpr3Dview->ResetCamera();
354 //-------------------------------------------------------------------------
355 void wxMaracas_ViewerWidget::Refresh(bool eraseBackground ,const wxRect* rect ) // virtual eraseBackground=true , rect=NULL
357 wxPanel::Refresh(false);
360 //-------------------------------------------------------------------------
361 void wxMaracas_ViewerWidget::RefreshView()
363 if (mwxvtk3Dbaseview_Clipping3D !=NULL ){ mwxvtk3Dbaseview_Clipping3D->Refresh(); }
364 if (mwxvtkclipping3Dview !=NULL ){ mwxvtkclipping3Dview->Refresh(); }
365 if (mwxvtkmpr3Dview !=NULL ){ mwxvtkmpr3Dview->RefreshView(); }
366 if (mvtk2Dbaseview !=NULL ){ mvtk2Dbaseview->Refresh(); }
367 if (mvtkmpr2Dview_X !=NULL ){ mvtkmpr2Dview_X->Refresh(); }
368 if (mvtkmpr2Dview_Y !=NULL ){ mvtkmpr2Dview_Y->Refresh(); }
369 if (mvtkmpr2Dview_Z !=NULL ){ mvtkmpr2Dview_Z->Refresh(); }
370 if (mvtkplane2Dview !=NULL ){ mvtkplane2Dview->Refresh(); }
371 if (mwxsphereview !=NULL ){ mwxsphereview ->RefreshView(); }
374 //-------------------------------------------------------------------------
376 wxVtkBaseView *wxMaracas_ViewerWidget::GetwxVtkBaseView()
378 wxVtkBaseView *wxvtkbaseview=NULL;
379 if (mvtk2Dbaseview!=NULL){
380 wxvtkbaseview = mvtk2Dbaseview;
382 if (mvtkmpr2Dview_X!=NULL){
383 wxvtkbaseview = mvtkmpr2Dview_X;
385 if (mvtkmpr2Dview_Y!=NULL){
386 wxvtkbaseview = mvtkmpr2Dview_Y;
388 if (mvtkmpr2Dview_Z!=NULL){
389 wxvtkbaseview = mvtkmpr2Dview_Z;
391 if (mvtkplane2Dview!=NULL){
392 wxvtkbaseview = mvtkplane2Dview;
394 if (mwxsphereview!=NULL){
395 wxvtkbaseview = mwxsphereview;
397 if (mwxvtk3Dbaseview_Clipping3D!=NULL){
398 wxvtkbaseview = mwxvtk3Dbaseview_Clipping3D;
400 return wxvtkbaseview ;
405 //-------------------------------------------------------------------------
406 void wxMaracas_ViewerWidget::SetImage( vtkImageData *image )
408 if(mvtkmprbasedata !=NULL)
410 marImageData* mar = mvtkmprbasedata->GetMarImageData();
411 mar->removeImageData(0);
412 mar->AddImageData(image);
415 if (mvtk2Dbaseview!=NULL)
417 mvtk2Dbaseview->SetImageToVtkViewer(image);
420 if (mvtkmpr2Dview_X!=NULL)
422 mvtkmpr2Dview_X->SetImageToVtkViewer(image);
424 if (mvtkmpr2Dview_Y!=NULL)
426 mvtkmpr2Dview_Y->SetImageToVtkViewer(image);
428 if (mvtkmpr2Dview_Z!=NULL)
430 mvtkmpr2Dview_Z->SetImageToVtkViewer(image);
433 if (mvtkplane2Dview!=NULL)
435 // ??? EED 10 oct 2012
437 if (mwxsphereview!=NULL)
439 mwxsphereview->SetImage();
441 if (mwxvtkclipping3Dview!=NULL)
443 mwxvtkclipping3Dview->GetVtkClipping3DDataViewer()->SetImage();
446 if (mwxvtkmpr3Dview!=NULL)
448 mwxvtkmpr3Dview->SetImage();
457 //-------------------------------------------------------------------------
459 double wxMaracas_ViewerWidget :: GetX()
462 if(mvtkmprbasedata !=NULL)
464 value = mvtkmprbasedata->GetX();
469 //-------------------------------------------------------------------------
471 double wxMaracas_ViewerWidget::GetY()
474 if(mvtkmprbasedata !=NULL)
476 value = mvtkmprbasedata->GetY();
481 //-------------------------------------------------------------------------
483 double wxMaracas_ViewerWidget::GetZ()
486 if(mvtkmprbasedata !=NULL)
488 value = mvtkmprbasedata->GetZ();
491 // return mvtk2Dbaseview->GetVtkBaseData()->GetZ();
494 //-------------------------------------------------------------------------------------------
495 void wxMaracas_ViewerWidget::setColorTransferFunction(vtkColorTransferFunction* colortable)
497 if(mvtkmpr2Dview_X!=NULL)
499 mvtkmpr2Dview_X->setColorTransferFunction(colortable);
502 if(mvtkmpr2Dview_Y!=NULL)
504 mvtkmpr2Dview_Y->setColorTransferFunction(colortable);
507 if(mvtkmpr2Dview_Z!=NULL)
509 mvtkmpr2Dview_Z->setColorTransferFunction(colortable);
512 if(mwxvtkmpr3Dview!=NULL)
514 mwxvtkmpr3Dview->setColorTransferFunction(colortable);
518 //-------------------------------------------------------------------------------------------
519 void wxMaracas_ViewerWidget::SetColorWindowLevel(double colorWindow, double colorLevel)
521 mvtkmprbasedata->SetColorWindow(colorWindow);
522 mvtkmprbasedata->SetColorLevel(colorLevel);
526 if(mvtk2Dbaseview!=NULL)
528 mvtk2Dbaseview->SetColorWindow(level);
531 if(mvtkmpr2Dview_X!=NULL)
533 mvtkmpr2Dview_X->SetColorWindow(level);
536 if(mvtkmpr2Dview_Y!=NULL)
538 mvtkmpr2Dview_Y->SetColorWindow(level);
541 if(mvtkmpr2Dview_Z!=NULL)
543 mvtkmpr2Dview_Z->SetColorWindow(level);
546 if(mwxvtkmpr3Dview!=NULL)
548 mwxvtkmpr3Dview->SetColorWindow(level);