X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FmaracasVisuLib%2Fsrc%2Finterface%2FwxWindows%2Fwidgets%2FwxVtkBaseView.cxx;h=65a1fdc78633f42c58ad94983bdbae3e7ad982eb;hb=401bb9b06310683e21d0a7676ef543fb9255f1f9;hp=c2be59111ba4abc2bda1004f1806f2f3f53aae4f;hpb=31f62e211fad94014168485d32c5e3ca936da953;p=creaMaracasVisu.git diff --git a/lib/maracasVisuLib/src/interface/wxWindows/widgets/wxVtkBaseView.cxx b/lib/maracasVisuLib/src/interface/wxWindows/widgets/wxVtkBaseView.cxx index c2be591..65a1fdc 100644 --- a/lib/maracasVisuLib/src/interface/wxWindows/widgets/wxVtkBaseView.cxx +++ b/lib/maracasVisuLib/src/interface/wxWindows/widgets/wxVtkBaseView.cxx @@ -90,9 +90,9 @@ vtkRenderWindow* wxVtkBaseView::GetRenWin() // virtual } //---------------------------------------------------------------------------- - -void wxVtkBaseView::TransCoordScreenToWorld(double &X, double &Y, double &Z) -{ + +void wxVtkBaseView::TransFromCoordScreenToWorld(double &X, double &Y, double &Z, bool is3D, bool keepNormalDirection, int type) //virtual //is3d=false keepNormalDirection=false, type=2 +{ GetRenderer()->SetDisplayPoint((int)X, (int)Y, (int)Z); GetRenderer()->DisplayToWorld(); double fP[4]; @@ -103,43 +103,34 @@ void wxVtkBaseView::TransCoordScreenToWorld(double &X, double &Y, double &Z) fP[2] /= fP[3]; } - X = fP[0]; - Y = fP[1]; - Z = fP[2]; -} -//---------------------------------------------------------------------------- - -void wxVtkBaseView::TransFromCoordScreenToWorld(double &X, double &Y, double &Z, bool keepNormalDirection, int type) //virtual //keepNormalDirection=false, type=2 -{ - - //RaC 03-2010 - TransCoordScreenToWorld(X,Y,Z); - -// EEDx5 - //JCP 13/05/2009 - vtkInteractorStyleBaseView* interactorstyle = (vtkInteractorStyleBaseView*)this->GetInteractorStyleBaseView(); - wxVtk2DBaseView* baseview = (wxVtk2DBaseView*)interactorstyle->GetWxVtk2DBaseView(); - - double fP[3]; - fP[0] = X; - fP[1] = Y; - fP[2] = Z; - - baseview->TransformCoordinate_spacing_ViewToModel( fP[0] , fP[1] , fP[2] ); - //JCP 13/05/2009 - - if (type!=0) + if(is3D) { X=fP[0]; - } - if (type!=1) - { Y=fP[1]; + Z=fP[2]; } - if (type!=2) + else { - Z=fP[2]; - } + // EEDx5 + //JCP 13/05/2009 + vtkInteractorStyleBaseView* interactorstyle = (vtkInteractorStyleBaseView*)this->GetInteractorStyleBaseView(); + wxVtk2DBaseView* baseview = (wxVtk2DBaseView*)interactorstyle->GetWxVtk2DBaseView(); + baseview->TransformCoordinate_spacing_ViewToModel( fP[0] , fP[1] , fP[2] ); + //JCP 13/05/2009 + + if (type!=0) + { + X=fP[0]; + } + if (type!=1) + { + Y=fP[1]; + } + if (type!=2) + { + Z=fP[2]; + } + } } //---------------------------------------------------------------------------