Program: wxMaracas
Module: $RCSfile: wxMaracas_ViewerWidget.cxx,v $
Language: C++
- Date: $Date: 2009/03/24 10:49:21 $
- Version: $Revision: 1.4 $
+ Date: $Date: 2010/01/21 13:54:15 $
+ Version: $Revision: 1.22 $
Copyright: (c) 2002, 2003
License:
//------------------------------------------------------------------------------------------------------------
- wxMaracas_ViewerWidget::wxMaracas_ViewerWidget(wxWindow *parent, vtkImageData* imagedata, int type)
+ wxMaracas_ViewerWidget::wxMaracas_ViewerWidget(wxWindow *parent, vtkImageData* imagedata, int type, vtkMPRBaseData *vtkmprbasedata)
: wxPanel( parent, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL)
{
wxPanel *panel = this;
- wxWindow *wxwindow = NULL;
+ wxWindow *wxwindow = NULL, *window3D = 0;
+ double xSpacing, ySpacing, zSpacing;
+ int xMin, xMax, yMin, yMax, zMin, zMax;
+ wxSplitterWindow *panelClipping3D = 0;
+ wxPanel *panelControl = 0, *controlPanelMPR3D = 0, *controlPanelClipping3D = 0;
+ wxFlexGridSizer *sizerCtrol = 0;
+ vtkCellPicker* picker = 0;
+ wxBoxSizer *sizer = 0;
+
mType = type;
- marImageData *marimagedata = new marImageData( imagedata );
- mvtkmprbasedata = new vtkMPRBaseData();
- mvtkmprbasedata->SetMarImageData(marimagedata);
+
+ if (vtkmprbasedata==NULL)
+ {
+ minternalVtkmprbasedata = true;
+ mvtkmprbasedata = new vtkMPRBaseData();
+ marImageData *marimagedata = new marImageData( imagedata );
+ mvtkmprbasedata->SetMarImageData(marimagedata);
+ } else {
+ minternalVtkmprbasedata = false;
+ mvtkmprbasedata = vtkmprbasedata;
+ }
+
mvtk2Dbaseview = NULL;
mvtkmpr2Dview_X = NULL;
mwxsphereview = NULL;
mwxvtkclipping3Dview = NULL;
mwxvtk3Dbaseview_Clipping3D = NULL;
- mwxvtkmpr3Dview = NULL;
+ mwxvtkmpr3Dview = NULL;
+ vtkmpr3Ddataviewer = NULL;
- std::cout<<"mtype "<<mType<<std::endl;
- std::cout<<"type "<<type<<std::endl;
if (type==-1)
{
mvtk2Dbaseview = new wxVtk2DBaseView(panel);
mvtk2Dbaseview->SetVtkBaseData(mvtkmprbasedata);
wxwindow = mvtk2Dbaseview->GetWxVTKRenderWindowInteractor();
- }
-
-
- if (type==0)
+ }else if (type==0)
{
- mvtkmpr2Dview_Z = new wxVtkMPR2DView(panel,0);
+ mvtkmpr2Dview_Z = new wxVtkMPR2DView(panel,2);
mvtkmpr2Dview_Z->SetVtkBaseData(mvtkmprbasedata);
wxwindow = mvtkmpr2Dview_Z->GetWxVTKRenderWindowInteractor();
- }
- if (type==1)
+ }else if (type==1)
{
- mvtkmpr2Dview_X = new wxVtkMPR2DView(panel,1);
+ mvtkmpr2Dview_X = new wxVtkMPR2DView(panel,0);
mvtkmpr2Dview_X->SetVtkBaseData(mvtkmprbasedata);
wxwindow = mvtkmpr2Dview_X->GetWxVTKRenderWindowInteractor();
- }
-
- if (type==2)
+ }else if (type==2)
{
- mvtkmpr2Dview_Y = new wxVtkMPR2DView(panel,2);
+ mvtkmpr2Dview_Y = new wxVtkMPR2DView(panel,1);
mvtkmpr2Dview_Y->SetVtkBaseData(mvtkmprbasedata);
wxwindow = mvtkmpr2Dview_Y->GetWxVTKRenderWindowInteractor();
- }
-
-
- if (type==3)
+ }else if (type==3)
{
mwidgetMesure = new wxWidgetMesure2D_Plane_in_MPR(panel);
mvtkplane2Dview = new vtkPlane2DView( mwidgetMesure->GetWindow2());
mvtkplane2Dview -> SetImgSize( 200 );
mvtkplane2Dview -> SetVtkBaseData(mvtkmprbasedata);
wxwindow = mwidgetMesure;
- }
- if (type==4)
+ }else if (type==4)
{
mwxsphereview = new wxSphereView( panel , mvtkmprbasedata, mvtkmprbasedata->GetImageData() );
wxwindow=mwxsphereview->GetWxVTKRenderWindowInteractor();
- }
-
-
- if (type==5)
+ }else if (type==5)
{
- wxSplitterWindow *panelClipping3D = new wxSplitterWindow( panel , -1);
+ panelClipping3D = new wxSplitterWindow( panel , -1);
mwxvtk3Dbaseview_Clipping3D = new wxVtk3DBaseView( panelClipping3D );
mwxvtkclipping3Dview = new wxVtkClipping3DView(mwxvtk3Dbaseview_Clipping3D);
vtkmpr3Ddataviewer->Configure();
mwxvtkmpr3Dview->SetVtkMPR3DDataViewer(vtkmpr3Ddataviewer);
- wxWindow *window3D = mwxvtk3Dbaseview_Clipping3D->GetWxVTKRenderWindowInteractor();
+ window3D = mwxvtk3Dbaseview_Clipping3D->GetWxVTKRenderWindowInteractor();
- wxPanel *panelControl = new wxPanel(panelClipping3D,-1);
- wxPanel *controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(panelControl);
- wxPanel *controlPanelClipping3D = mwxvtkclipping3Dview->CreateControlPanel(panelControl);
+ panelControl = new wxPanel(panelClipping3D,-1);
+ controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(panelControl, false);
+ controlPanelClipping3D = mwxvtkclipping3Dview->CreateControlPanel(panelControl);
// mbtnCutImageData = new wxCheckBox(panelControl,-1,_T("Cut Module"));
// Connect(_btnCutImageData->GetId() , wxEVT_COMMAND_CHECKBOX_CLICKED , (wxObjectEventFunction) &wxMPRWidget::OnCutImagaData );
- wxFlexGridSizer *sizerCtrol = new wxFlexGridSizer(1);
+ sizerCtrol = new wxFlexGridSizer(1);
sizerCtrol->Add(controlPanelMPR3D , 1, wxALL|wxEXPAND, 2);
sizerCtrol->Add(controlPanelClipping3D , 1, wxALL|wxEXPAND, 2);
// sizerCtrol->Add( mbtnCutImageData , 1, wxALL, 2);
panelClipping3D -> SetMinimumPaneSize( 5 );
panelClipping3D -> SplitHorizontally( panelControl , window3D , 10 );
wxwindow=panelClipping3D;
- }
-
- if (type==6)
+ }else if (type==6)
{
- wxSplitterWindow *panelClipping3D = new wxSplitterWindow( panel , -1);
+ panelClipping3D = new wxSplitterWindow( panel , -1);
mwxvtk3Dbaseview_Clipping3D = new wxVtk3DBaseView( panelClipping3D );
mwxvtkmpr3Dview = new wxVtkMPR3DView( mwxvtk3Dbaseview_Clipping3D );
- vtkMPR3DDataViewer *vtkmpr3Ddataviewer = new vtkMPR3DDataViewer();
- vtkmpr3Ddataviewer->SetVtkMPRBaseData(mvtkmprbasedata);
- vtkmpr3Ddataviewer->Configure();
- mwxvtkmpr3Dview->SetVtkMPR3DDataViewer(vtkmpr3Ddataviewer);
+
+
+ vtkmpr3Ddataviewer = new vtkMPR3DDataViewer();
+
+
+
wxWindow *window3D = mwxvtk3Dbaseview_Clipping3D->GetWxVTKRenderWindowInteractor();
wxPanel *panelControl = new wxPanel(panelClipping3D,-1);
- wxPanel *controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(panelControl);
+ wxPanel *controlPanelMPR3D = mwxvtkmpr3Dview->CreateControlPanel(panelControl, false);
wxFlexGridSizer *sizerCtrol = new wxFlexGridSizer(1);
sizerCtrol->Add(controlPanelMPR3D , 1, wxALL|wxEXPAND, 2);
panelClipping3D -> SetMinimumPaneSize( 5 );
panelClipping3D -> SplitHorizontally( panelControl , window3D , 10 );
wxwindow=panelClipping3D;
- }
+ vtkmpr3Ddataviewer->SetVtkMPRBaseData(mvtkmprbasedata);
+ //vtkmpr3Ddataviewer->Configure();
+
+ mwxvtkmpr3Dview->SetVtkMPR3DDataViewer(vtkmpr3Ddataviewer);
+
+ }else if (type==7)
+ {
+
+ mwxvtk3Dbaseview_Clipping3D = new wxVtk3DBaseView( panel );
+ wxwindow = (wxWindow*) mwxvtk3Dbaseview_Clipping3D->GetWxVTKRenderWindowInteractor();
+
+
+ }
- wxBoxSizer *sizer = new wxBoxSizer(wxVERTICAL);
+
+ sizer = new wxBoxSizer(wxVERTICAL);
sizer->Add( wxwindow , 1, wxGROW);
panel->SetSizer(sizer);
panel->SetAutoLayout(true);
wxMaracas_ViewerWidget::~wxMaracas_ViewerWidget()
{
-
- testDelete(mvtkmprbasedata);
- testDelete(mvtk2Dbaseview);
- testDelete(mvtkmpr2Dview_X);
- testDelete(mvtkmpr2Dview_Y);
- testDelete(mvtkmpr2Dview_Z);
- testDelete(mwidgetMesure);
- testDelete(mvtkplane2Dview);
- testDelete(mwxsphereview);
- testDelete(mwxvtkclipping3Dview);
- testDelete(mwxvtk3Dbaseview_Clipping3D);
- testDelete(mwxvtkmpr3Dview);
-
- }
-
- void wxMaracas_ViewerWidget::testDelete(void* point){
- if(point!=NULL){
- delete point;
- }
+
+ if (minternalVtkmprbasedata==true)
+ {
+ if (mvtkmprbasedata) { delete mvtkmprbasedata; }
+ }
+
+ if (mvtk2Dbaseview) { delete mvtk2Dbaseview; }
+ if (mvtkmpr2Dview_X) { delete mvtkmpr2Dview_X; }
+ if (mvtkmpr2Dview_Y) { delete mvtkmpr2Dview_Y; }
+ if (mvtkmpr2Dview_Z) { delete mvtkmpr2Dview_Z; }
+ if (mwidgetMesure) { delete mwidgetMesure; }
+ if (mvtkplane2Dview) { delete mvtkplane2Dview; }
+ if (mwxsphereview) { delete mwxsphereview; }
+ if (mwxvtkmpr3Dview) { delete mwxvtkmpr3Dview; }
+ if (mwxvtkclipping3Dview) { delete mwxvtkclipping3Dview; }
+ if (mwxvtk3Dbaseview_Clipping3D){ delete mwxvtk3Dbaseview_Clipping3D; mwxvtk3Dbaseview_Clipping3D=NULL;}
}
-
//------------------------------------------------------------------------------------------------------------
// Methods
//------------------------------------------------------------------------------------------------------------
//-------------------------------------------------------------------------
+
void wxMaracas_ViewerWidget::ConfigureVTK()
{
int x=0,y=0,z=0;
+ int ext[6];
+ ext[0]=0;
+ ext[1]=0;
+ ext[2]=0;
+ ext[3]=0;
+ ext[4]=0;
+ ext[5]=0;
+ double org[3],spc[3];
+ org[0]=0;
+ org[1]=0;
+ org[2]=0;
+ spc[0]=0;
+ spc[1]=0;
+ spc[2]=0;
+
+
+
+ if (mvtkmprbasedata!=NULL)
+ {
+ mvtkmprbasedata->Configure();
+ /*x = mvtkmprbasedata -> GetMaxPositionX()/2;
+ y = mvtkmprbasedata -> GetMaxPositionY()/2;
+ z = mvtkmprbasedata -> GetMaxPositionZ()/2; */
+
+ if(mvtkmprbasedata->GetImageData() != NULL)
+ {
+ mvtkmprbasedata->GetImageData()->GetExtent(ext);
+ mvtkmprbasedata->GetImageData()->GetOrigin(org);
+ mvtkmprbasedata->GetImageData()->GetSpacing(spc);
+
+ x = (ext[0]+ext[1])/2;
+ y = (ext[2]+ext[3])/2;
+ z = (ext[4]+ext[5])/2;
+
+ mvtkmprbasedata->SetX( x );
+ mvtkmprbasedata->SetY( y );
+ mvtkmprbasedata->SetZ( z );
+ }
+ else
+ {
+ mvtkmprbasedata->SetX( 0 );
+ mvtkmprbasedata->SetY( 0 );
+ mvtkmprbasedata->SetZ( 0 );
+ }
+ }
+
if ( mvtk2Dbaseview !=NULL ) { mvtk2Dbaseview -> Configure(); }
if ( mvtkmpr2Dview_X !=NULL ) { mvtkmpr2Dview_X -> Configure(); }
if ( mwidgetMesure !=NULL ) { mwidgetMesure -> SetMesureScale( 1 ); }
if ( mwxsphereview !=NULL ) { mwxsphereview -> Configure(); }
- if (mwxvtk3Dbaseview_Clipping3D !=NULL) { mwxvtk3Dbaseview_Clipping3D -> Configure(); }
- if (mwxvtkmpr3Dview !=NULL) { mwxvtkmpr3Dview -> Configure(); }
+ if (mwxvtk3Dbaseview_Clipping3D !=NULL) {
+ mwxvtk3Dbaseview_Clipping3D -> Configure();
+
+ }
+
+ if (vtkmpr3Ddataviewer !=NULL) {
+ vtkmpr3Ddataviewer->Configure();
+
+ }
+ if (mwxvtkmpr3Dview !=NULL) {
+
+ mwxvtkmpr3Dview -> Configure();
+ mwxvtkmpr3Dview ->ResetCamera(ext,org,spc);
+
+
+ }
+
if (mwxvtkclipping3Dview !=NULL) { mwxvtkclipping3Dview -> Configure(); }
+
+
+
+
+
+
+
+
+ //if(vtkmpr3Ddataviewer!=NULL){vtkmpr3Ddataviewer->Configure();}
+// RefreshView();
+
+ //if (mwxvtkmpr3Dview !=NULL) {
+ // mwxvtkmpr3Dview->ResetCamera();
+ //}
- if (mvtkmprbasedata!=NULL)
- {
- x = mvtkmprbasedata -> GetMaxPositionX()/2;
- y = mvtkmprbasedata -> GetMaxPositionY()/2;
- z = mvtkmprbasedata -> GetMaxPositionZ()/2;
- mvtkmprbasedata->SetX( x );
- mvtkmprbasedata->SetY( y );
- mvtkmprbasedata->SetZ( z );
- }
- RefreshView();
}
//-------------------------------------------------------------------------
//-------------------------------------------------------------------------
void wxMaracas_ViewerWidget::RefreshView()
{
+
if (mvtk2Dbaseview !=NULL ){ mvtk2Dbaseview -> Refresh(); }
if (mvtkmpr2Dview_X !=NULL ){ mvtkmpr2Dview_X -> Refresh(); }
if (mvtkmpr2Dview_Y !=NULL ){ mvtkmpr2Dview_Y -> Refresh(); }
if (mwxvtkmpr3Dview !=NULL ){ mwxvtkmpr3Dview -> RefreshView(); }
if (mwxvtkclipping3Dview !=NULL ){ mwxvtkclipping3Dview -> Refresh(); }
if (mwxvtk3Dbaseview_Clipping3D !=NULL ){ mwxvtk3Dbaseview_Clipping3D -> Refresh(); }
+
}
//-------------------------------------------------------------------------
wxVtkBaseView *wxMaracas_ViewerWidget::GetwxVtkBaseView()
{
wxVtkBaseView *wxvtkbaseview=NULL;
- if (mvtk2Dbaseview!=NULL) { wxvtkbaseview = mvtk2Dbaseview; }
- if (mvtkmpr2Dview_X!=NULL) { wxvtkbaseview = mvtkmpr2Dview_X; }
- if (mvtkmpr2Dview_Y!=NULL) { wxvtkbaseview = mvtkmpr2Dview_Y; }
- if (mvtkmpr2Dview_Z!=NULL) { wxvtkbaseview = mvtkmpr2Dview_Z; }
- if (mvtkplane2Dview!=NULL) { wxvtkbaseview = mvtkplane2Dview; }
- if (mwxsphereview!=NULL) { wxvtkbaseview = mwxsphereview; }
- if (mwxvtk3Dbaseview_Clipping3D!=NULL) { wxvtkbaseview = mwxvtk3Dbaseview_Clipping3D;}
+ if (mvtk2Dbaseview!=NULL) {
+ wxvtkbaseview = mvtk2Dbaseview;
+ }
+ if (mvtkmpr2Dview_X!=NULL){
+ wxvtkbaseview = mvtkmpr2Dview_X;
+ }
+ if (mvtkmpr2Dview_Y!=NULL){
+ wxvtkbaseview = mvtkmpr2Dview_Y;
+ }
+ if (mvtkmpr2Dview_Z!=NULL){
+ wxvtkbaseview = mvtkmpr2Dview_Z;
+ }
+ if (mvtkplane2Dview!=NULL){
+ wxvtkbaseview = mvtkplane2Dview;
+ }
+ if (mwxsphereview!=NULL){
+ wxvtkbaseview = mwxsphereview;
+ }
+ if (mwxvtk3Dbaseview_Clipping3D!=NULL) {
+ wxvtkbaseview = mwxvtk3Dbaseview_Clipping3D;
+ }
return wxvtkbaseview ;
}
void wxMaracas_ViewerWidget::SetImage( vtkImageData *image )
{
- //printf("EED wxMaracas_ViewerWidget::SetImage IMPORTANT this methode is missing \n");
- marImageData* mar = mvtkmprbasedata->GetMarImageData();
- mar->removeImageData(0);
- mar->AddImageData(image);
-
- ConfigureVTK();
- RefreshView();
-
-
+ if(mvtkmprbasedata !=NULL)
+ {
+ marImageData* mar = mvtkmprbasedata->GetMarImageData();
+ mar->removeImageData(0);
+ mar->AddImageData(image);
+ }
+//EED 26/11/2009
+// ConfigureVTK();
+// RefreshView();
}
double wxMaracas_ViewerWidget :: GetX()
{
- return mvtkmprbasedata->GetX();
+ double value = -1;
+ if(mvtkmprbasedata !=NULL)
+ {
+ value = mvtkmprbasedata->GetX();
+ }
+ return value;
}
double wxMaracas_ViewerWidget :: GetY()
{
- return mvtkmprbasedata->GetY();
+ double value = -1;
+ if(mvtkmprbasedata !=NULL)
+ {
+ value = mvtkmprbasedata->GetY();
+ }
+ return value;
}
double wxMaracas_ViewerWidget :: GetZ()
{
- return mvtkmprbasedata->GetZ();
+ double value = -1;
+ if(mvtkmprbasedata !=NULL)
+ {
+ value = mvtkmprbasedata->GetZ();
+ }
+ return value;
// return mvtk2Dbaseview->GetVtkBaseData()->GetZ();
}
+ void wxMaracas_ViewerWidget::setColorTransferFunction(vtkColorTransferFunction* colortable){
+ if(mvtkmpr2Dview_X!=NULL){
+ mvtkmpr2Dview_X->setColorTransferFunction(colortable);
+ }
+ if(mvtkmpr2Dview_Y!=NULL){
+ mvtkmpr2Dview_Y->setColorTransferFunction(colortable);
+ }
+ if(mvtkmpr2Dview_Z!=NULL){
+ mvtkmpr2Dview_Z->setColorTransferFunction(colortable);
+ }
+ if(mwxvtkmpr3Dview!=NULL){
+ mwxvtkmpr3Dview->setColorTransferFunction(colortable);
+ }
+ }
+
+ void wxMaracas_ViewerWidget::setWindowLevel(double level){
+ if(mvtkmpr2Dview_X!=NULL){
+ mvtkmpr2Dview_X->setWindowLevel(level);
+ }
+ if(mvtkmpr2Dview_Y!=NULL){
+ mvtkmpr2Dview_Y->setWindowLevel(level);
+ }
+ if(mvtkmpr2Dview_Z!=NULL){
+ mvtkmpr2Dview_Z->setWindowLevel(level);
+ }
+ /*if(mwxvtkmpr3Dview!=NULL){
+ mwxvtkmpr3Dview->setWindowLevel(level);
+ }*/
+ }
+
+ void wxMaracas_ViewerWidget::setColorLevel(double level){
+ if(mvtkmpr2Dview_X!=NULL){
+ mvtkmpr2Dview_X->setColorLevel(level);
+ }
+ if(mvtkmpr2Dview_Y!=NULL){
+ mvtkmpr2Dview_Y->setColorLevel(level);
+ }
+ if(mvtkmpr2Dview_Z!=NULL){
+ mvtkmpr2Dview_Z->setColorLevel(level);
+ }
+ /*if(mwxvtkmpr3Dview!=NULL){
+ mwxvtkmpr3Dview->setColorLevel(level);
+ }*/
+ }
+
+
+