]> Creatis software - creaMaracasVisu.git/blobdiff - lib/maracasVisuLib/src/interface/wxWindows/widgets/manualPaint/vtkInteractorManualPaint.cpp
#2855 creaMaracasVisu Bug New Normal - ColorLayer box spacing size not identified
[creaMaracasVisu.git] / lib / maracasVisuLib / src / interface / wxWindows / widgets / manualPaint / vtkInteractorManualPaint.cpp
index 65d918efffedb5c09b5e3d5fd5c0c380809d1366..b6af3ea5366170be78d96c35361e72fbba9e7eca 100644 (file)
@@ -1,41 +1,59 @@
+/*# ---------------------------------------------------------------------
+#
+# Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
+#                        pour la Sant�)
+# Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
+# Previous Authors : Laurent Guigues, Jean-Pierre Roux
+# CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
+#
+#  This software is governed by the CeCILL-B license under French law and
+#  abiding by the rules of distribution of free software. You can  use,
+#  modify and/ or redistribute the software under the terms of the CeCILL-B
+#  license as circulated by CEA, CNRS and INRIA at the following URL
+#  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
+#  or in the file LICENSE.txt.
+#
+#  As a counterpart to the access to the source code and  rights to copy,
+#  modify and redistribute granted by the license, users are provided only
+#  with a limited warranty  and the software's author,  the holder of the
+#  economic rights,  and the successive licensors  have only  limited
+#  liability.
+#
+#  The fact that you are presently reading this means that you have had
+#  knowledge of the CeCILL-B license and that you accept its terms.
+# ------------------------------------------------------------------------ */
 
 #include "vtkInteractorManualPaint.h"
 
-
 #include "wxVtk2DBaseView.h"
 #include "wxVTKRenderWindowInteractor.h"
 
-
-vtkInteractorManualPaint::vtkInteractorManualPaint(ManualPaintControler* mpc)
-{
-    _manualPaintControler   = mpc;
-       _state                  = false;
-       _stateKey               = false;
+vtkInteractorManualPaint::vtkInteractorManualPaint(ManualPaintControler* mpc) {
+       _manualPaintControler = mpc;
+       _state          = false;
+       _stateKey       = false;
+       _stateMouse = false;
 }
 
 //---------------------------------------------------------------------------
-vtkInteractorManualPaint::~vtkInteractorManualPaint()
-{
+vtkInteractorManualPaint::~vtkInteractorManualPaint() {
 }
 
 //---------------------------------------------------------------------------
-bool vtkInteractorManualPaint::OnChar()
-{
+bool vtkInteractorManualPaint::OnChar() {
        vtkRenderWindowInteractor *interactor = _vtkInteractorStyleBaseView->GetInteractor();
-       
-       if  (interactor->GetKeyCode()==97)
-       {
-               _stateKey=!_stateKey;
+       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();
        }
@@ -43,46 +61,47 @@ bool vtkInteractorManualPaint::OnLeftButtonDown()
 }
 
 //---------------------------------------------------------------------------
-bool vtkInteractorManualPaint::OnLeftButtonUp()
-{
+bool vtkInteractorManualPaint::OnLeftButtonUp() {
+    if((_state == true) || (_stateKey == true))
+       _manualPaintControler->SetImageUndo();
        _state = false;
        return true;
 }
 
 //---------------------------------------------------------------------------
-bool vtkInteractorManualPaint::OnMouseMove ()
+bool vtkInteractorManualPaint::OnMouseMove() 
 {
-       if ((_state==true) || (_stateKey==true))
+       if ((_state == true) || (_stateKey == true)) 
        {
-               std::cout<<"Pechaaaaaannnnnnn!!!!"<<std::endl;
-        wxVtk2DBaseView             *wxvtk2Dbaseview    = (wxVtk2DBaseView*)_vtkInteractorStyleBaseView->GetWxVtk2DBaseView();
-        wxVTKRenderWindowInteractor *wxVTKiren          = wxvtk2Dbaseview->GetWxVTKRenderWindowInteractor();
-        int px,py;
-        wxVTKiren->GetEventPosition(px,py);
+               wxVtk2DBaseView *wxvtk2Dbaseview =
+                               (wxVtk2DBaseView*) _vtkInteractorStyleBaseView->GetWxVtk2DBaseView();
+               wxVTKRenderWindowInteractor *wxVTKiren =
+                               wxvtk2Dbaseview->GetWxVTKRenderWindowInteractor();
+               int px, py;
+               wxVTKiren->GetEventPosition(px, py);
 
 //        int     typeView = 1;
-        double  X        = (double)px;
-        double  Y        = (double)py;
-        double  Z        =  wxvtk2Dbaseview->GetActualSlice();
+               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);
+               wxvtk2Dbaseview->TransFromCoordScreenToWorld(X, Y, Z, true);
 
-        _manualPaintControler->PaintImage((int)X,(int)Y,(int)Z);
-        this->_vtkInteractorStyleBaseView->SetParent_refresh_waiting();
+               _manualPaintControler->PaintImage((int) X, (int) Y, (int) Z);
+               this->_vtkInteractorStyleBaseView->SetParent_refresh_waiting();
 
-/*
-        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;
 }
 
-