2 # ---------------------------------------------------------------------
4 # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
6 # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
8 # This software is governed by the CeCILL-B license under French law and
9 # abiding by the rules of distribution of free software. You can use,
10 # modify and/ or redistribute the software under the terms of the CeCILL-B
11 # license as circulated by CEA, CNRS and INRIA at the following URL
12 # http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
13 # or in the file LICENSE.txt.
15 # As a counterpart to the access to the source code and rights to copy,
16 # modify and redistribute granted by the license, users are provided only
17 # with a limited warranty and the software's author, the holder of the
18 # economic rights, and the successive licensors have only limited
21 # The fact that you are presently reading this means that you have had
22 # knowledge of the CeCILL-B license and that you accept its terms.
23 # ------------------------------------------------------------------------
26 /*=========================================================================
32 =========================================================================*/
34 /* ---------------------------------------------------------------------
36 * Copyright (c) CREATIS-LRMN (Centre de Recherche en Imagerie Medicale)
37 * Authors : Eduardo Davila, Laurent Guigues, Jean-Pierre Roux
39 * This software is governed by the CeCILL-B license under French law and
40 * abiding by the rules of distribution of free software. You can use,
41 * modify and/ or redistribute the software under the terms of the CeCILL-B
42 * license as circulated by CEA, CNRS and INRIA at the following URL
43 * http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
44 * or in the file LICENSE.txt.
46 * As a counterpart to the access to the source code and rights to copy,
47 * modify and redistribute granted by the license, users are provided only
48 * with a limited warranty and the software's author, the holder of the
49 * economic rights, and the successive licensors have only limited
52 * The fact that you are presently reading this means that you have had
53 * knowledge of the CeCILL-B license and that you accept its terms.
54 * ------------------------------------------------------------------------ */
58 * \brief Class bbtk::GConnectorController
62 #include "GConnectorController.h"
71 //=========================================================================
72 GConnectorController::GConnectorController()
77 //=========================================================================
79 GConnectorController::~GConnectorController()
83 //=========================================================================
85 bool GConnectorController::OnMouseMove()
88 if (_view->getState() ==SELECTED)
90 _controller->GetManualViewBaseContour()->SetSelected(true);
93 if ( _vtkInteractorStyleBaseView!=NULL)
96 crea::wxVTKRenderWindowInteractor *_wxVTKiren;
97 _wxVTKiren= _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
98 _wxVTKiren->GetEventPosition( X , Y );
100 if ( (_vtkInteractorStyleBaseView->GetInteractor()->GetControlKey()==0) &&(_vtkInteractorStyleBaseView->GetInteractor()->GetShiftKey()==0) )
102 _controller->MouseMove(X,Y);
109 //=========================================================================
111 bool GConnectorController::OnLeftButtonDown()
114 if ( _vtkInteractorStyleBaseView!=NULL )
117 crea::wxVTKRenderWindowInteractor *wxVTKiren;
118 wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
119 wxVTKiren->GetEventPosition(X,Y);
121 _controller->SetKeyBoardMoving( false );
122 _controller->MouseClickLeft(X,Y);
128 //=========================================================================
130 bool GConnectorController::OnLeftButtonUp()
132 if( _vtkInteractorStyleBaseView!= NULL )
135 crea::wxVTKRenderWindowInteractor *wxVTKiren;
136 wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
137 wxVTKiren->GetEventPosition(X, Y);
139 _controller->MouseReleaseLeft(X,Y);
140 if(_controller->GetManualViewBaseContour()->GetSelected()==true)
142 _view->setState(SELECTED);
143 _model->notifyObservers(getId(),ADD_TO_SELECTED);
151 //=========================================================================
153 bool GConnectorController::OnLeftDClick()
156 if ( _vtkInteractorStyleBaseView!=NULL )
159 crea::wxVTKRenderWindowInteractor *wxVTKiren;
160 wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
161 wxVTKiren->GetEventPosition(X,Y);
163 _controller->MouseDLeft(X,Y);
169 //=========================================================================
171 bool GConnectorController::OnRightButtonDown()
173 if( _vtkInteractorStyleBaseView!= NULL )
176 crea::wxVTKRenderWindowInteractor *wxVTKiren;
177 wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
178 wxVTKiren->GetEventPosition(X, Y);
180 _controller->MouseClickRight(X,Y);
186 //=========================================================================
188 bool GConnectorController::OnRightButtonUp()
193 //=========================================================================
195 bool GConnectorController::OnMiddleButtonDown()
197 if ( _vtkInteractorStyleBaseView!=NULL )
199 int X, Y, Z=GPOSITION_Z;
200 crea::wxVTKRenderWindowInteractor *wxVTKiren;
201 wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
202 wxVTKiren->GetEventPosition(X, Y);
203 _controller->GetManualViewBaseContour()->InitMove( X, Y,Z);
207 //=========================================================================
208 bool GConnectorController::OnMiddleButtonUp()
213 //=========================================================================
215 manualConnectorContourController* GConnectorController::getManualContourController()
220 //=========================================================================
222 void GConnectorController::setManualContourController(manualConnectorContourController* controller)
224 _controller = controller;
225 _controller->SetVtkInteractorStyleBaseView(_vtkInteractorStyleBaseView);
228 //=========================================================================
230 void GConnectorController::removeFromScene()
232 GConnectorModel *conMod = (GConnectorModel*)_model;
233 conMod->disconnectConnection();
235 _controller->SetEditable(false);
236 _controller->DeleteContour();
239 //=========================================================================
241 void GConnectorController::endContourCreation()
243 _controller->endContourCreation();
246 //=========================================================================
248 } // EO namespace bbtk