1 /*=========================================================================
4 Module: $RCSfile: wxMaracas_ViewerWidget.cxx,v $
6 Date: $Date: 2009/05/07 15:35:46 $
7 Version: $Revision: 1.11 $
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"
23 //------------------------------------------------------------------------------------------------------------
25 //------------------------------------------------------------------------------------------------------------
28 //------------------------------------------------------------------------------------------------------------
29 // Constructors & Destructors
30 //------------------------------------------------------------------------------------------------------------
33 wxMaracas_ViewerWidget::wxMaracas_ViewerWidget(wxWindow *parent, vtkImageData* imagedata, int type)
34 : wxPanel( parent, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL)
36 wxPanel *panel = this;
37 wxWindow *wxwindow = NULL;
41 marImageData *marimagedata = new marImageData( imagedata );
42 mvtkmprbasedata = new vtkMPRBaseData();
43 mvtkmprbasedata->SetMarImageData(marimagedata);
45 mvtk2Dbaseview = NULL;
46 mvtkmpr2Dview_X = NULL;
47 mvtkmpr2Dview_Y = NULL;
48 mvtkmpr2Dview_Z = NULL;
49 mvtkplane2Dview = NULL;
52 mwxvtkclipping3Dview = NULL;
53 mwxvtk3Dbaseview_Clipping3D = NULL;
54 mwxvtkmpr3Dview = NULL;
55 vtkmpr3Ddataviewer = NULL;
60 mvtk2Dbaseview = new wxVtk2DBaseView(panel);
61 mvtk2Dbaseview->SetVtkBaseData(mvtkmprbasedata);
62 wxwindow = mvtk2Dbaseview->GetWxVTKRenderWindowInteractor();
68 mvtkmpr2Dview_Z = new wxVtkMPR2DView(panel,2);
69 mvtkmpr2Dview_Z->SetVtkBaseData(mvtkmprbasedata);
70 wxwindow = mvtkmpr2Dview_Z->GetWxVTKRenderWindowInteractor();
74 mvtkmpr2Dview_X = new wxVtkMPR2DView(panel,0);
75 mvtkmpr2Dview_X->SetVtkBaseData(mvtkmprbasedata);
76 wxwindow = mvtkmpr2Dview_X->GetWxVTKRenderWindowInteractor();
81 mvtkmpr2Dview_Y = new wxVtkMPR2DView(panel,1);
82 mvtkmpr2Dview_Y->SetVtkBaseData(mvtkmprbasedata);
83 wxwindow = mvtkmpr2Dview_Y->GetWxVTKRenderWindowInteractor();
89 mwidgetMesure = new wxWidgetMesure2D_Plane_in_MPR(panel);
90 mvtkplane2Dview = new vtkPlane2DView( mwidgetMesure->GetWindow2());
91 mwidgetMesure -> SetVtkPlane2DView( mvtkplane2Dview );
92 mvtkplane2Dview -> SetImgSize( 200 );
93 mvtkplane2Dview -> SetVtkBaseData(mvtkmprbasedata);
94 wxwindow = mwidgetMesure;
98 mwxsphereview = new wxSphereView( panel , mvtkmprbasedata, mvtkmprbasedata->GetImageData() );
99 wxwindow=mwxsphereview->GetWxVTKRenderWindowInteractor();
105 wxSplitterWindow *panelClipping3D = new wxSplitterWindow( panel , -1);
106 mwxvtk3Dbaseview_Clipping3D = new wxVtk3DBaseView( panelClipping3D );
108 mwxvtkclipping3Dview = new wxVtkClipping3DView(mwxvtk3Dbaseview_Clipping3D);
109 vtkClipping3DDataViewer *vtkclipping3Ddataviewer = new vtkClipping3DDataViewer();
110 vtkclipping3Ddataviewer->SetVtkMPRBaseData(mvtkmprbasedata);
111 vtkclipping3Ddataviewer->Configure();
112 mwxvtkclipping3Dview->SetVtkClipping3DDataViewer(vtkclipping3Ddataviewer);
114 mwxvtkmpr3Dview = new wxVtkMPR3DView( mwxvtk3Dbaseview_Clipping3D );
115 vtkMPR3DDataViewer *vtkmpr3Ddataviewer = new vtkMPR3DDataViewer();
116 vtkmpr3Ddataviewer->SetVtkMPRBaseData(mvtkmprbasedata);
117 vtkmpr3Ddataviewer->Configure();
118 mwxvtkmpr3Dview->SetVtkMPR3DDataViewer(vtkmpr3Ddataviewer);
120 wxWindow *window3D = mwxvtk3Dbaseview_Clipping3D->GetWxVTKRenderWindowInteractor();
122 wxPanel *panelControl = new wxPanel(panelClipping3D,-1);
123 wxPanel *controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(panelControl);
124 wxPanel *controlPanelClipping3D = mwxvtkclipping3Dview->CreateControlPanel(panelControl);
125 // mbtnCutImageData = new wxCheckBox(panelControl,-1,_T("Cut Module"));
126 // Connect(_btnCutImageData->GetId() , wxEVT_COMMAND_CHECKBOX_CLICKED , (wxObjectEventFunction) &wxMPRWidget::OnCutImagaData );
128 wxFlexGridSizer *sizerCtrol = new wxFlexGridSizer(1);
129 sizerCtrol->Add(controlPanelMPR3D , 1, wxALL|wxEXPAND, 2);
130 sizerCtrol->Add(controlPanelClipping3D , 1, wxALL|wxEXPAND, 2);
131 // sizerCtrol->Add( mbtnCutImageData , 1, wxALL, 2);
133 panelControl->SetAutoLayout(true);
134 panelControl->SetSizer(sizerCtrol);
135 panelControl->SetSize(400,350);
136 panelControl->Layout();
137 panelClipping3D -> SetMinimumPaneSize( 5 );
138 panelClipping3D -> SplitHorizontally( panelControl , window3D , 10 );
139 wxwindow=panelClipping3D;
144 wxSplitterWindow *panelClipping3D = new wxSplitterWindow( panel , -1);
145 mwxvtk3Dbaseview_Clipping3D = new wxVtk3DBaseView( panelClipping3D );
147 mwxvtkmpr3Dview = new wxVtkMPR3DView( mwxvtk3Dbaseview_Clipping3D );
149 vtkmpr3Ddataviewer = new vtkMPR3DDataViewer();
151 wxWindow *window3D = mwxvtk3Dbaseview_Clipping3D->GetWxVTKRenderWindowInteractor();
153 wxPanel *panelControl = new wxPanel(panelClipping3D,-1);
154 wxPanel *controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(panelControl);
156 wxFlexGridSizer *sizerCtrol = new wxFlexGridSizer(1);
157 sizerCtrol->Add(controlPanelMPR3D , 1, wxALL|wxEXPAND, 2);
159 panelControl->SetAutoLayout(true);
160 panelControl->SetSizer(sizerCtrol);
161 panelControl->SetSize(400,350);
162 panelControl->Layout();
163 panelClipping3D -> SetMinimumPaneSize( 5 );
164 panelClipping3D -> SplitHorizontally( panelControl , window3D , 10 );
165 wxwindow=panelClipping3D;
168 vtkmpr3Ddataviewer->SetVtkMPRBaseData(mvtkmprbasedata);
169 //vtkmpr3Ddataviewer->Configure();
171 mwxvtkmpr3Dview->SetVtkMPR3DDataViewer(vtkmpr3Ddataviewer);
177 wxBoxSizer *sizer = new wxBoxSizer(wxVERTICAL);
178 sizer->Add( wxwindow , 1, wxGROW);
179 panel->SetSizer(sizer);
180 panel->SetAutoLayout(true);
185 // mbbtkViewerMaracas= NULL;
187 //-------------------------------------------------------------------------
189 wxMaracas_ViewerWidget::~wxMaracas_ViewerWidget()
191 if (mvtkmprbasedata) { delete mvtkmprbasedata; }
192 if (mvtk2Dbaseview) { delete mvtk2Dbaseview; }
193 if (mvtkmpr2Dview_X) { delete mvtkmpr2Dview_X; }
194 if (mvtkmpr2Dview_Y) { delete mvtkmpr2Dview_Y; }
195 if (mvtkmpr2Dview_Z) { delete mvtkmpr2Dview_Z; }
196 if (mwidgetMesure) { delete mwidgetMesure; }
197 if (mvtkplane2Dview) { delete mvtkplane2Dview; }
198 if (mwxsphereview) { delete mwxsphereview; }
199 if (mwxvtkclipping3Dview) { delete mwxvtkclipping3Dview; }
200 if (mwxvtk3Dbaseview_Clipping3D){ delete mwxvtk3Dbaseview_Clipping3D; }
201 if (mwxvtkmpr3Dview) { delete mwxvtkmpr3Dview; }
204 //------------------------------------------------------------------------------------------------------------
206 //------------------------------------------------------------------------------------------------------------
208 //-------------------------------------------------------------------------
210 void wxMaracas_ViewerWidget::ConfigureVTK()
220 double org[3],spc[3];
230 if (mvtkmprbasedata!=NULL)
232 mvtkmprbasedata->Configure();
233 /*x = mvtkmprbasedata -> GetMaxPositionX()/2;
234 y = mvtkmprbasedata -> GetMaxPositionY()/2;
235 z = mvtkmprbasedata -> GetMaxPositionZ()/2; */
237 mvtkmprbasedata->GetImageData()->GetExtent(ext);
238 mvtkmprbasedata->GetImageData()->GetOrigin(org);
239 mvtkmprbasedata->GetImageData()->GetSpacing(spc);
241 x = (ext[0]+ext[1])/2;
242 y = (ext[2]+ext[3])/2;
243 z = (ext[4]+ext[5])/2;
245 mvtkmprbasedata->SetX( x );
246 mvtkmprbasedata->SetY( y );
247 mvtkmprbasedata->SetZ( z );
252 if ( mvtk2Dbaseview !=NULL ) { mvtk2Dbaseview -> Configure(); }
253 if ( mvtkmpr2Dview_X !=NULL ) { mvtkmpr2Dview_X -> Configure(); }
254 if ( mvtkmpr2Dview_Y !=NULL ) { mvtkmpr2Dview_Y -> Configure(); }
255 if ( mvtkmpr2Dview_Z !=NULL ) { mvtkmpr2Dview_Z -> Configure(); }
256 if ( mvtkplane2Dview !=NULL ) { mvtkplane2Dview -> Configure(); }
257 if ( mwidgetMesure !=NULL ) { mwidgetMesure -> ConfigureA(mvtkplane2Dview);}
258 if ( mwidgetMesure !=NULL ) { mwidgetMesure -> ConfigureA(mvtkplane2Dview);}
259 if ( mwidgetMesure !=NULL ) { mwidgetMesure -> SetActiveLink(true); }
260 if ( mwidgetMesure !=NULL ) { mwidgetMesure -> SetMesureScale( 1 ); }
261 if ( mwxsphereview !=NULL ) { mwxsphereview -> Configure(); }
263 if (mwxvtk3Dbaseview_Clipping3D !=NULL) { mwxvtk3Dbaseview_Clipping3D -> Configure(); }
265 if (vtkmpr3Ddataviewer !=NULL) {
266 vtkmpr3Ddataviewer->Configure();
269 if (mwxvtkmpr3Dview !=NULL) {
271 mwxvtkmpr3Dview -> Configure();
272 mwxvtkmpr3Dview ->ResetCamera(ext,org,spc);
277 if (mwxvtkclipping3Dview !=NULL) { mwxvtkclipping3Dview -> Configure(); }
283 //if(vtkmpr3Ddataviewer!=NULL){vtkmpr3Ddataviewer->Configure();}
286 //if (mwxvtkmpr3Dview !=NULL) {
287 // mwxvtkmpr3Dview->ResetCamera();
292 //-------------------------------------------------------------------------
294 void wxMaracas_ViewerWidget::Refresh(bool eraseBackground ,const wxRect* rect ) // virtual eraseBackground=true , rect=NULL
296 wxPanel::Refresh(false);
299 //-------------------------------------------------------------------------
300 void wxMaracas_ViewerWidget::RefreshView()
303 if (mvtk2Dbaseview !=NULL ){ mvtk2Dbaseview -> Refresh(); }
304 if (mvtkmpr2Dview_X !=NULL ){ mvtkmpr2Dview_X -> Refresh(); }
305 if (mvtkmpr2Dview_Y !=NULL ){ mvtkmpr2Dview_Y -> Refresh(); }
306 if (mvtkmpr2Dview_Z !=NULL ){ mvtkmpr2Dview_Z -> Refresh(); }
307 if (mvtkplane2Dview !=NULL ){ mvtkplane2Dview -> Refresh(); }
308 if (mwxsphereview !=NULL ){ mwxsphereview -> Refresh(); }
310 if (mwxvtkmpr3Dview !=NULL ){ mwxvtkmpr3Dview -> RefreshView(); }
311 if (mwxvtkclipping3Dview !=NULL ){ mwxvtkclipping3Dview -> Refresh(); }
312 if (mwxvtk3Dbaseview_Clipping3D !=NULL ){ mwxvtk3Dbaseview_Clipping3D -> Refresh(); }
316 //-------------------------------------------------------------------------
318 wxVtkBaseView *wxMaracas_ViewerWidget::GetwxVtkBaseView()
320 wxVtkBaseView *wxvtkbaseview=NULL;
321 if (mvtk2Dbaseview!=NULL) {
322 wxvtkbaseview = mvtk2Dbaseview;
324 if (mvtkmpr2Dview_X!=NULL){
325 wxvtkbaseview = mvtkmpr2Dview_X;
327 if (mvtkmpr2Dview_Y!=NULL){
328 wxvtkbaseview = mvtkmpr2Dview_Y;
330 if (mvtkmpr2Dview_Z!=NULL){
331 wxvtkbaseview = mvtkmpr2Dview_Z;
333 if (mvtkplane2Dview!=NULL){
334 wxvtkbaseview = mvtkplane2Dview;
336 if (mwxsphereview!=NULL){
337 wxvtkbaseview = mwxsphereview;
339 if (mwxvtk3Dbaseview_Clipping3D!=NULL) {
340 wxvtkbaseview = mwxvtk3Dbaseview_Clipping3D;
342 return wxvtkbaseview ;
345 void wxMaracas_ViewerWidget::SetImage( vtkImageData *image )
347 marImageData* mar = mvtkmprbasedata->GetMarImageData();
348 mar->removeImageData(0);
349 mar->AddImageData(image);
358 double wxMaracas_ViewerWidget :: GetX()
360 return mvtkmprbasedata->GetX();
363 double wxMaracas_ViewerWidget :: GetY()
365 return mvtkmprbasedata->GetY();
368 double wxMaracas_ViewerWidget :: GetZ()
370 return mvtkmprbasedata->GetZ();
371 // return mvtk2Dbaseview->GetVtkBaseData()->GetZ();