X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FmaracasVisuLib%2Fsrc%2Finterface%2FwxWindows%2Fwidgets%2FmanualPaint%2FvtkInteractorManualPaint.cpp;h=82a82c74c6f5ab90afd24af006fc6403f149e81a;hb=5380f9e66daf440f27f33bb060e5ae1a646612cd;hp=0a9a18f6a5437500e9990ed4dba371ff30594a70;hpb=965c602117e9de99019d49bd78ca1d707a1a6bd2;p=creaMaracasVisu.git diff --git a/lib/maracasVisuLib/src/interface/wxWindows/widgets/manualPaint/vtkInteractorManualPaint.cpp b/lib/maracasVisuLib/src/interface/wxWindows/widgets/manualPaint/vtkInteractorManualPaint.cpp index 0a9a18f..82a82c7 100644 --- a/lib/maracasVisuLib/src/interface/wxWindows/widgets/manualPaint/vtkInteractorManualPaint.cpp +++ b/lib/maracasVisuLib/src/interface/wxWindows/widgets/manualPaint/vtkInteractorManualPaint.cpp @@ -1,29 +1,36 @@ - #include "vtkInteractorManualPaint.h" - #include "wxVtk2DBaseView.h" #include "wxVTKRenderWindowInteractor.h" +vtkInteractorManualPaint::vtkInteractorManualPaint(ManualPaintControler* mpc) { + _manualPaintControler = mpc; + _state = false; + _stateKey = false; + _stateMouse = false; +} -vtkInteractorManualPaint::vtkInteractorManualPaint(ManualPaintControler* mpc) -{ - _manualPaintControler = mpc; - _state = false; -// _auxZ = 0; +//--------------------------------------------------------------------------- +vtkInteractorManualPaint::~vtkInteractorManualPaint() { } //--------------------------------------------------------------------------- -vtkInteractorManualPaint::~vtkInteractorManualPaint() -{ +bool vtkInteractorManualPaint::OnChar() { + vtkRenderWindowInteractor *interactor = + _vtkInteractorStyleBaseView->GetInteractor(); + + if (interactor->GetKeyCode() == 97) { + _stateKey = !_stateKey; + } + return true; } //--------------------------------------------------------------------------- -bool vtkInteractorManualPaint::OnLeftButtonDown() -{ - vtkRenderWindowInteractor *interactor = _vtkInteractorStyleBaseView->GetInteractor(); - if ( interactor->GetControlKey()==1 ){ - _state = true; +bool vtkInteractorManualPaint::OnLeftButtonDown() { + vtkRenderWindowInteractor *interactor = + _vtkInteractorStyleBaseView->GetInteractor(); + if (interactor->GetControlKey() == 1) { + _state = true; // wxVtk2DBaseView *wxvtk2Dbaseview = (wxVtk2DBaseView*)_vtkInteractorStyleBaseView->GetWxVtk2DBaseView(); // _Z = wxvtk2Dbaseview->GetActualSlice(); } @@ -31,46 +38,45 @@ bool vtkInteractorManualPaint::OnLeftButtonDown() } //--------------------------------------------------------------------------- -bool vtkInteractorManualPaint::OnLeftButtonUp() -{ +bool vtkInteractorManualPaint::OnLeftButtonUp() { + if((_state == true) || (_stateKey == true)) + _manualPaintControler->SetImageUndo(); _state = false; return true; } //--------------------------------------------------------------------------- -bool vtkInteractorManualPaint::OnMouseMove () -{ - if (_state==true) - { - wxVtk2DBaseView *wxvtk2Dbaseview = (wxVtk2DBaseView*)_vtkInteractorStyleBaseView->GetWxVtk2DBaseView(); - wxVTKRenderWindowInteractor *wxVTKiren = wxvtk2Dbaseview->GetWxVTKRenderWindowInteractor(); - int px,py; - wxVTKiren->GetEventPosition(px,py); +bool vtkInteractorManualPaint::OnMouseMove() { + if ((_state == true) || (_stateKey == true)) { + wxVtk2DBaseView *wxvtk2Dbaseview = + (wxVtk2DBaseView*) _vtkInteractorStyleBaseView->GetWxVtk2DBaseView(); + wxVTKRenderWindowInteractor *wxVTKiren = + wxvtk2Dbaseview->GetWxVTKRenderWindowInteractor(); + int px, py; + wxVTKiren->GetEventPosition(px, py); - int typeView = 2; - double X = (double)px; - double Y = (double)py; - double Z = wxvtk2Dbaseview->GetActualSlice(); - wxvtk2Dbaseview->TransFromCoordScreenToWorld(X, Y, Z,false, typeView); +// int typeView = 1; + double X = (double) px; + double Y = (double) py; + double Z = wxvtk2Dbaseview->GetActualSlice(); +// wxvtk2Dbaseview->TransFromCoordScreenToWorld(X, Y, Z,true, typeView); + wxvtk2Dbaseview->TransFromCoordScreenToWorld(X, Y, Z, true); -// int px = _vtkInteractorStyleBaseView->GetInteractor()->GetEventPosition()[0]; -// int py = _vtkInteractorStyleBaseView->GetInteractor()->GetEventPosition()[1]; + _manualPaintControler->PaintImage((int) X, (int) Y, (int) Z); + this->_vtkInteractorStyleBaseView->SetParent_refresh_waiting(); - _manualPaintControler->PaintImage((int)X,(int)Y,(int)Z); - -/* - wxvtk2Dbaseview->_imageViewer2XYZ->GetVtkImageViewer2()->Modified(); - wxvtk2Dbaseview->_imageViewer2XYZ->GetVtkImageViewer2()->GetImageActor()->Modified(); - wxvtk2Dbaseview->_imageViewer2XYZ->GetVtkImageViewer2()->GetImageActor()->SetDisplayExtent(0, 50+_auxZ, 0, 50,_Z, _Z ); - wxvtk2Dbaseview->Refresh(); - wxvtk2Dbaseview->RefreshView(); -// wxvtk2Dbaseview->SetActualSlice(_Z+_auxZ); - _auxZ=(_auxZ+1)%2; - wxvtk2Dbaseview->_imageViewer2XYZ->GetVtkImageViewer2()->GetRenderer()->Render(); - this->_vtkInteractorStyleBaseView->SetParent_refresh_waiting(); -*/ - }// if _state + /* + wxvtk2Dbaseview->_imageViewer2XYZ->GetVtkImageViewer2()->Modified(); + wxvtk2Dbaseview->_imageViewer2XYZ->GetVtkImageViewer2()->GetImageActor()->Modified(); + wxvtk2Dbaseview->_imageViewer2XYZ->GetVtkImageViewer2()->GetImageActor()->SetDisplayExtent(0, 50+_auxZ, 0, 50,_Z, _Z ); + wxvtk2Dbaseview->Refresh(); + wxvtk2Dbaseview->RefreshView(); + // wxvtk2Dbaseview->SetActualSlice(_Z+_auxZ); + _auxZ=(_auxZ+1)%2; + wxvtk2Dbaseview->_imageViewer2XYZ->GetVtkImageViewer2()->GetRenderer()->Render(); + this->_vtkInteractorStyleBaseView->SetParent_refresh_waiting(); + */ + } // if _state return true; } -