X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FEditorGraphicBBS%2FbbsVtkGUIEditorGraphic%2FGPortController.cxx;h=c15a276efc67696d6fc55d0fed343ae5f1a939a9;hb=a6d479881eeb637cd06afa3b2177e430fa05571e;hp=c9c196b2ad776da0d7103006618c9234291cd4f0;hpb=0b3b25440d23eabf549ebdfa0a4a39ea91ea2f23;p=bbtkGEditor.git diff --git a/lib/EditorGraphicBBS/bbsVtkGUIEditorGraphic/GPortController.cxx b/lib/EditorGraphicBBS/bbsVtkGUIEditorGraphic/GPortController.cxx index c9c196b..c15a276 100644 --- a/lib/EditorGraphicBBS/bbsVtkGUIEditorGraphic/GPortController.cxx +++ b/lib/EditorGraphicBBS/bbsVtkGUIEditorGraphic/GPortController.cxx @@ -43,7 +43,7 @@ namespace bbtk //========================================================================= GPortController::GPortController() { - + _isLeftClickDown=false; } //========================================================================= @@ -55,65 +55,49 @@ namespace bbtk bool GPortController::OnLeftButtonDown() { - if ( _vtkInteractorStyleBaseView!=NULL ) - { - int X,Y; - wxVTKRenderWindowInteractor *wxVTKiren; - wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor(); - wxVTKiren->GetEventPosition(X,Y); - - int state = _model->getState(); + int state = _view->getState(); - int portType = ((GPortModel*)_model)->getPortType(); - - //Evaluate new state - if(!_model->hasChanged() && state==HIGHLIGHTED && portType==GINPUTPORT ) - { - _model->setState(CREATING_CONTOUR); - _model->setChanged(); - } - - _model->notifyObservers(); - + //Evaluate new state + if(state == HIGHLIGHTED) + { + _isLeftClickDown=true; } return true; } //========================================================================= bool GPortController::OnLeftButtonUp() { - if ( _vtkInteractorStyleBaseView!=NULL ) + int state = _view->getState(); + if(_isLeftClickDown) { - int X,Y; - wxVTKRenderWindowInteractor *wxVTKiren; - wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor(); - wxVTKiren->GetEventPosition(X,Y); - - int state = _model->getState(); - - //Evaluate new state - if(!_model->hasChanged() && state==CREATING_CONTOUR) + if(state==HIGHLIGHTED) { - if(_view->isPointInside(X,Y)) + int portType = ((GPortModel*)_model)->getPortType(); + + //Evaluate new state + if(portType==GOUTPUTPORT) { - _model->setChanged(); - _model->notifyObservers(INIT_CREATION_CONTOUR); + _model->notifyObservers(getId(),INIT_CREATION_CONTOUR); } - else + else if (portType==GINPUTPORT) { - _model->setState(NOTHING_HAPPENS); - _model->setChanged(); - _model->notifyObservers(); + _model->notifyObservers(getId(),FIN_CREATION_CONTOUR); } } - - - + else + { + _view->setState(NOTHING_HAPPENS); + } + _isLeftClickDown=false; } + return true; } //========================================================================= + + } // EO namespace bbtk // EOF