]> Creatis software - creaMaracasVisu.git/blobdiff - lib/maracasVisuLib/src/interface/wxWindows/widgets/wxVtk2DBaseView.cxx
Bug #1679
[creaMaracasVisu.git] / lib / maracasVisuLib / src / interface / wxWindows / widgets / wxVtk2DBaseView.cxx
index 53bf04744c086cd71e34e37eb72281670ed24f8b..61607c373e2075bf13ba759877412a49b7a2f260 100644 (file)
@@ -8,32 +8,41 @@
 wxVtk2DBaseView::wxVtk2DBaseView(wxWindow *parent)
 :wxVtkBaseView(parent)
 {
-       _imageViewer2XYZ        = NULL;
-       _vtkIinfoTextImage      = NULL;
+   _imageViewer2XYZ   = NULL;
+   _vtkIinfoTextImage = NULL;
 }
 
 //EED 5mai2009
 //-------------------------------------------------------------------
 wxVtk2DBaseView::~wxVtk2DBaseView()
-{      
-       if (_vtkIinfoTextImage!=NULL) 
+{
+       if (_vtkIinfoTextImage!=NULL)
        {
-               delete _vtkIinfoTextImage; 
+          delete _vtkIinfoTextImage;
        }
 
-       if (_imageViewer2XYZ!=NULL) 
+       if (_imageViewer2XYZ!=NULL)
        {
-               delete _imageViewer2XYZ; 
+          delete _imageViewer2XYZ;
        }
 }
 
 //-------------------------------------------------------------------
-void wxVtk2DBaseView::TransformCoordinate_spacing_ViewToModel(double &X,double &Y, double &Z) //       virtual 
+void wxVtk2DBaseView::TransformCoordinate_spacing_ViewToModel(double &X,double &Y, double &Z) //       virtual
 {
 //EEDx5
        double spc[3];
 //     GetVtkBaseData()->GetImageData()->GetSpacing(spc);
-       this->_imageViewer2XYZ->GetVtkImageViewer2()->GetInput()->GetSpacing(spc);
+//JCP 04/08/10 W/O Image this->_imageViewer2XYZ->GetVtkImageViewer2()->GetInput()->GetSpacing(spc);
+       vtkImageData* image = this->_imageViewer2XYZ->GetVtkImageViewer2()->GetInput();
+       if(image){
+               image->GetSpacing(spc);
+       }else{
+               spc[0] = 1;
+               spc[1] = 1;
+               spc[2] = 1;
+       }
+
 
        X = X / spc[0];
        Y = Y / spc[1];
@@ -42,13 +51,21 @@ void wxVtk2DBaseView::TransformCoordinate_spacing_ViewToModel(double &X,double &
 }
 
 //-------------------------------------------------------------------
-void wxVtk2DBaseView::TransformCoordinate_spacing_ModelToView(double &X,double &Y, double &Z) //       virtual 
+void wxVtk2DBaseView::TransformCoordinate_spacing_ModelToView(double &X,double &Y, double &Z) //       virtual
 {
 //EEDx5
        double spc[3];
 //     GetVtkBaseData()->GetImageData()->GetSpacing(spc);
-       this->_imageViewer2XYZ->GetVtkImageViewer2()->GetInput()->GetSpacing(spc);
-
+//JCP 04/08/10 W/O Image this->_imageViewer2XYZ->GetVtkImageViewer2()->GetInput()->GetSpacing(spc);
+       vtkImageData* image = this->_imageViewer2XYZ->GetVtkImageViewer2()->GetInput();
+       if(image){
+               image->GetSpacing(spc);
+       }else{
+               spc[0] = 1;
+               spc[1] = 1;
+               spc[2] = 1;
+       }
+//
        X=X*spc[0];
        Y=Y*spc[1];
        Z=Z*spc[2];
@@ -58,25 +75,62 @@ void wxVtk2DBaseView::TransformCoordinate_spacing_ModelToView(double &X,double &
 //-------------------------------------------------------------------
 void wxVtk2DBaseView::ResetView()
 {
-       double spx,spy,spz;
-       int x1,x2,y1,y2,z1,z2;
+       printf("EED wxVtk2DBaseView::ResetView");
+       double spx = 0,spy = 0,spz = 0;
+       int x1 = 1,x2 = 1,y1 = 1,y2 = 1,z1 = 1,z2 = 1;
        wxVtkBaseView::Configure();
-       
+
        wxVTKRenderWindowInteractor *iren = GetWxVTKRenderWindowInteractor();
        vtkImageData *imageData = GetVtkBaseData()->GetImageData();
-       imageData->UpdateInformation();
-       imageData->SetUpdateExtent( imageData->GetWholeExtent());
-       imageData->Update();
+       if(imageData){
+               imageData->UpdateInformation();
+               imageData->SetUpdateExtent( imageData->GetWholeExtent());
+               imageData->Update();
+               _imageViewer2XYZ->GetVtkImageViewer2()->SetInput(imageData );
+               imageData->GetSpacing (spx,spy,spz);
+               imageData->GetExtent (x1,x2,y1,y2,z1,z2);
+       }
+
 
-       _imageViewer2XYZ->GetVtkImageViewer2()->SetInput(imageData );
-       imageData->GetSpacing (spx,spy,spz);
-       imageData->GetExtent (x1,x2,y1,y2,z1,z2);
        _imageViewer2XYZ -> SetExtentDimension(x1,x2,y1,y2,z1,z2);
        _imageViewer2XYZ -> GetVtkImageViewer2()->SetupInteractor ( iren );
 
+//EED 24oct2010
+    _imageViewer2XYZ->GetVtkImageViewer2()->GetWindowLevel()->Modified();
+
        _imageViewer2XYZ->GetVtkImageViewer2()->Render();
-       SetInteractorStyleImage( vtkInteractorStyleBaseView2D::New() );
-       
+
+       //////////////
+       //RaC 04-2010 Look for the description of new changes in vtkInteractorStyleBaseView2D constructor.
+       //
+       // Previous version
+       // SetInteractorStyleImage( vtkInteractorStyleBaseView2D::New() );
+       //
+       // Actual version
+       vtkInteractorStyleBaseView2D *style2D = vtkInteractorStyleBaseView2D::New();
+
+       manualInteractorWindowLevel *_manualinteractorwindowlevel= new manualInteractorWindowLevel();
+       style2D->SetInteractorWindowLevel( _manualinteractorwindowlevel );
+
+       vtkInteractorScrollZ *_vtkInteractorScrollZ = new vtkInteractorScrollZ();
+       style2D->SetInteractorScrollZ(_vtkInteractorScrollZ);
+
+       SetInteractorStyleImage( style2D );
+
+       // RaC
+       //////////////
+
+}
+
+
+
+//-------------------------------------------------------------------
+void wxVtk2DBaseView::SetImageToVtkViewer(vtkImageData *imageData)
+{
+       if (_imageViewer2XYZ!=NULL)
+       {
+               _imageViewer2XYZ->GetVtkImageViewer2()->SetInput( imageData );
+       } // if _imageViewer2XYZ
 }
 
 
@@ -88,36 +142,54 @@ void wxVtk2DBaseView::Configure(bool okimage)
        wxVtkBaseView::Configure();
 
 // EED 17 Oct 2007
-                       if (_imageViewer2XYZ==NULL)
-                       {
-                               _imageViewer2XYZ = new vtkImageViewer2_XYZ();
-                               wxVTKRenderWindowInteractor *iren = GetWxVTKRenderWindowInteractor();
-                               _imageViewer2XYZ -> GetVtkImageViewer2()->SetupInteractor ( iren );
-                               SetInteractorStyleImage( vtkInteractorStyleBaseView2D::New() );
-                       }
+       if (_imageViewer2XYZ==NULL)
+       {
+               _imageViewer2XYZ = new vtkImageViewer2_XYZ();
+               wxVTKRenderWindowInteractor *iren = GetWxVTKRenderWindowInteractor();
+               _imageViewer2XYZ -> GetVtkImageViewer2()->SetupInteractor ( iren );
+
+               //////////////
+               //RaC 04-2010 Look for the description of new changes in vtkInteractorStyleBaseView2D constructor.
+               //
+               // Previous version
+               // SetInteractorStyleImage( vtkInteractorStyleBaseView2D::New() );
+               //
+               // Actual version
+               vtkInteractorStyleBaseView2D *style2D = vtkInteractorStyleBaseView2D::New();
+
+               manualInteractorWindowLevel *_manualinteractorwindowlevel= new manualInteractorWindowLevel();
+               style2D->SetInteractorWindowLevel( _manualinteractorwindowlevel );
+
+               vtkInteractorScrollZ *_vtkInteractorScrollZ = new vtkInteractorScrollZ();
+               style2D->SetInteractorScrollZ(_vtkInteractorScrollZ);
+
+               SetInteractorStyleImage( style2D );
+
+               // RaC
+               //////////////
+       }
 
 
        vtkImageData *imageData = GetVtkBaseData()->GetMarImageData()->GetImageData();
-       if (imageData!=NULL){
+       if (imageData!=NULL)
+       {
                imageData->UpdateInformation();
                imageData->SetUpdateExtent( imageData->GetWholeExtent());
                imageData->Update();
                if (okimage==true){
                        imageData->GetSpacing (spx,spy,spz);
                        imageData->GetExtent (x1,x2,y1,y2,z1,z2);
-
-
-                       _imageViewer2XYZ->GetVtkImageViewer2()->SetInput(imageData );
+                       SetImageToVtkViewer(imageData);
                        _imageViewer2XYZ->SetExtentDimension(x1,x2,y1,y2,z1,z2);
                        double range[2];
-                         imageData->GetScalarRange(range);
-                         if (range[1]<20000){
+                       imageData->GetScalarRange(range);
+                       if (range[1]<20000){
                                 _imageViewer2XYZ->GetVtkImageViewer2()->SetColorWindow( (range[1]-range[0])/2 );
                                 _imageViewer2XYZ->GetVtkImageViewer2()->SetColorLevel( (range[1]+range[0])/4 );
-                         } else {
+                       } else {
                                 _imageViewer2XYZ->GetVtkImageViewer2()->SetColorWindow( 1000 );
                                 _imageViewer2XYZ->GetVtkImageViewer2()->SetColorLevel( 500 );
-                         }
+                       }
 // EED 31 Janvier 2007
 //vtkImageActor *vtkimageactor = _imageViewer2XYZ->GetVtkImageViewer2()->GetImageActor ();
 //vtkimageactor->InterpolateOff ();
@@ -135,72 +207,80 @@ void wxVtk2DBaseView::Configure(bool okimage)
 //                     SetInteractorStyleImage( vtkInteractorStyleBaseView2D::New() );
 
 
-                       vtkImageViewer2 *IV2=_imageViewer2XYZ->GetVtkImageViewer2();
-                       vtkCamera *camera = IV2->GetRenderer()->GetActiveCamera();
+                       vtkImageViewer2 *IV2            =       _imageViewer2XYZ->GetVtkImageViewer2();
+                       vtkCamera               *camera         =       IV2->GetRenderer()->GetActiveCamera();
 
-//EED 17Avril2009      
-/*                     
+//EED 17Avril2009
+//EED 21 mars 2012     FLIP problem  ..PLOP..
+                       
+                       // XY
                        camera->SetViewUp               ( spx*0                 , -spy*1                        , spz*0         );
-                       camera->SetPosition             ( spx*(x1+x2)/2 , spy*(y1+y2)/2 , -spz*10000    ); 
-                       camera->SetFocalPoint   ( spx*(x1+x2)/2 , spy*(y1+y2)/2 , spz*0         ); 
-*/ 
+                       camera->SetPosition             ( spx*(x1+x2)/2 , spy*(y1+y2)/2 , -spz*10000    );
+                       camera->SetFocalPoint   ( spx*(x1+x2)/2 , spy*(y1+y2)/2 , spz*0         );
+/*
                        camera->SetViewUp               ( spx*0                 , spy*1                 , spz*0         );
-                       camera->SetPosition             ( spx*(x1+x2)/2 , spy*(y1+y2)/2 , spz*10000     ); 
-                       camera->SetFocalPoint   ( spx*(x1+x2)/2 , spy*(y1+y2)/2 , spz*0         ); 
-                       
+                       camera->SetPosition             ( spx*(x1+x2)/2 , spy*(y1+y2)/2 , spz*10000     );
+                       camera->SetFocalPoint   ( spx*(x1+x2)/2 , spy*(y1+y2)/2 , spz*0         );
+*/
+
                        
                        camera->SetClippingRange( 0.01                  , 1000000 );
                        camera->ComputeViewPlaneNormal();
                        camera->SetParallelScale( spx*(x2-x1)/3.0 );
-                       
+
                        // text information over the graphic window
-                       _vtkIinfoTextImage                              = new vtkInfoTextImage();
-                       _vtkIinfoTextImageInteractor    = new vtkInfoTextImageInteractor();
+                       if(_vtkIinfoTextImage == NULL){
+                               _vtkIinfoTextImage                                      = new vtkInfoTextImage();
+                               _vtkIinfoTextImageInteractor            = new vtkInfoTextImageInteractor();
+                               ((vtkInteractorStyleBaseView*)this->GetInteractorStyleBaseView())->AddInteractorStyleMaracas(_vtkIinfoTextImageInteractor);
+                       }
                        _vtkIinfoTextImage->SetWxVtk2DBaseView(this);
                        _vtkIinfoTextImage->SetMarImageData( GetVtkBaseData()->GetMarImageData() );
-                       _vtkIinfoTextImageInteractor->SetModelVtkInfoTextImage(_vtkIinfoTextImage);     
+                       _vtkIinfoTextImageInteractor->SetModelVtkInfoTextImage(_vtkIinfoTextImage);
                        _vtkIinfoTextImage->Configure();
-                       ((vtkInteractorStyleBaseView*)this->GetInteractorStyleBaseView())->AddInteractorStyleMaracas(_vtkIinfoTextImageInteractor);
+
                } // okimage
        } // imageData
-
 }
 
 //-------------------------------------------------------------------
 
-int    wxVtk2DBaseView::GetActualSlice()  // virtual 
+int    wxVtk2DBaseView::GetActualSlice()  // virtual
 {
-       return (int)(_vtkbasedata->GetZ());
+   return (int)(_vtkbasedata->GetZ());
 }
 
 //-------------------------------------------------------------------
 void wxVtk2DBaseView::SetActualSlice(int slice)  // Virtual
 {
-       _vtkbasedata->SetZ(slice);
+   _vtkbasedata->SetZ(slice);
 }
 
 //-------------------------------------------------------------------
 
 vtkBaseData *wxVtk2DBaseView::GetVtkBaseData()
 {
-       return _vtkbasedata;
+   return _vtkbasedata;
 }
 
 //-------------------------------------------------------------------
 
 void wxVtk2DBaseView::SetVtkBaseData(vtkBaseData *vtkbasedata)
 {
-       _vtkbasedata=vtkbasedata;
+   _vtkbasedata=vtkbasedata;
 }
 
 //-------------------------------------------------------------------
 
 void wxVtk2DBaseView::Refresh()
 {
-       int z = (int)(GetVtkBaseData()->GetZ());
-       _imageViewer2XYZ->SetZSlice( z ); 
+   int z = (int)(GetVtkBaseData()->GetZ());
+  _imageViewer2XYZ->SetZSlice( z );
 
-       wxVtkBaseView::Refresh();
+//EED 24oct2010
+  _imageViewer2XYZ->GetVtkImageViewer2()->GetWindowLevel()->Modified();
+
+   wxVtkBaseView::Refresh();
 }
 
 //-------------------------------------------------------------------
@@ -212,7 +292,7 @@ void wxVtk2DBaseView::SetInteractorStyleImage(vtkInteractorStyleBaseView *intera
        wxVTKRenderWindowInteractor *iren = GetWxVTKRenderWindowInteractor();
        interactorstylebaseview->SetInteractor ( iren );
        iren->SetInteractorStyle(interactorstylebaseview);
-       interactorstylebaseview->SetwxVtkBaseView(this);        
+       interactorstylebaseview->SetwxVtkBaseView(this);
 
        vtkMaracasImageViewer2Callback * cbk = vtkMaracasImageViewer2Callback::New();
        cbk->IV = _imageViewer2XYZ->GetVtkImageViewer2();
@@ -223,20 +303,60 @@ void wxVtk2DBaseView::SetInteractorStyleImage(vtkInteractorStyleBaseView *intera
 }
 
 //---------------------------------------------------------------------------
-vtkRenderer* wxVtk2DBaseView::GetRenderer()    // virtual 
+vtkRenderer* wxVtk2DBaseView::GetRenderer()    // virtual
 {
-       return  _imageViewer2XYZ->GetVtkImageViewer2()->GetRenderer();
+   return _imageViewer2XYZ->GetVtkImageViewer2()->GetRenderer();
 }
 //---------------------------------------------------------------------------
 vtkRenderWindow* wxVtk2DBaseView::GetRenWin()          // virtual
 {
-       return  _imageViewer2XYZ->GetVtkImageViewer2()->GetRenderWindow();
+   return _imageViewer2XYZ->GetVtkImageViewer2()->GetRenderWindow();
 }
 
 //-------------------------------------------------------------------
-
 void wxVtk2DBaseView::GetSpacing(double spc[3])  // virtual
 {
-       vtkImageData *imageData = GetVtkBaseData()->GetImageData();
+   vtkImageData *imageData     = GetVtkBaseData()->GetImageData();
+   if(imageData){
        imageData->GetSpacing(spc);
-}
\ No newline at end of file
+   }else{
+        spc[0] = 0;
+        spc[1] = 0;
+        spc[2] = 0;
+   }
+}
+
+//-------------------------------------------------------------------
+void wxVtk2DBaseView::setColorTransferFunction(vtkColorTransferFunction* colortable)
+{
+       if(_imageViewer2XYZ!=NULL){
+               _imageViewer2XYZ->setColorTransferFunction(colortable);
+               this->Refresh();
+       }
+}
+
+//-------------------------------------------------------------------
+void wxVtk2DBaseView::setWindowLevel(double level)
+{
+//     _imageViewer2XYZ->GetVtkImageViewer2()->SetColorWindow(level);
+
+       vtkImageMapToWindowLevelColors* imagemaptowindowlevel = _imageViewer2XYZ->GetVtkImageViewer2()->GetWindowLevel();
+       imagemaptowindowlevel->SetWindow(level);
+       this->Refresh();
+}
+
+//-------------------------------------------------------------------
+void wxVtk2DBaseView::setColorLevel(double level)
+{
+//     _imageViewer2XYZ->GetVtkImageViewer2()->SetColorLevel(level);
+       vtkImageMapToWindowLevelColors* imagemaptowindowlevel = _imageViewer2XYZ->GetVtkImageViewer2()->GetWindowLevel();
+       imagemaptowindowlevel->SetLevel(level);
+       this->Refresh();
+}
+
+//-------------------------------------------------------------------
+int wxVtk2DBaseView::GetDirection() // virtual
+{
+    return 2;
+}
+