_wxVTKiren= _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
_wxVTKiren->GetEventPosition( X , Y );
- int state = _model->getState();
+ int state = _view->getState();
//Evaluate new state
- if(!_model->hasChanged() && state == DRAG)
- {
- moveObject(X,Y);
- _model->setChanged();
- }
-
- if(!_model->hasChanged() && state == NOTHING_HAPPENS)
+
+ if(state == NOTHING_HAPPENS)
{
if(_view->isPointInside(X,Y))
{
- _model->setState(HIGHLIGHTED);
- _model->setChanged();
+ _view->setState(HIGHLIGHTED);
}
}
- if(!_model->hasChanged() && state==HIGHLIGHTED)
+ if( state==HIGHLIGHTED)
{
if(!_view->isPointInside(X,Y))
{
- _model->setState(NOTHING_HAPPENS);
- _model->setChanged();
+ _view->setState(NOTHING_HAPPENS);
}
}
- _model->notifyObservers();
+ _model->notifyObservers(getId());
+
}
return true;
}
bool GBlackBoxController::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();
- //Evaluate new state
- if(!_model->hasChanged() && state==HIGHLIGHTED)
- {
- _view->isStartDragging(true);
- _model->setState(DRAG);
- _model->setChanged();
- }
-
- if( !_model->hasChanged() && state == SELECTED)
- {
- if(_view->isPointInside(X,Y))
- {
- _view->isStartDragging(true);
- _model->setState(DRAG);
- _model->setChanged();
- }
- }
-
- _model->notifyObservers();
+ //Evaluate new state
+ if(state == HIGHLIGHTED)
+ {
+ _isLeftClickDown=true;
+ _view->setState(SELECTED);
+ _model->notifyObservers(getId(),ADD_TO_SELECTED);
}
return true;
+
}
//=========================================================================
bool GBlackBoxController::OnLeftButtonUp()
{
- if ( _vtkInteractorStyleBaseView!=NULL )
- {
- int X,Y;
- wxVTKRenderWindowInteractor *wxVTKiren;
- wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
- wxVTKiren->GetEventPosition(X,Y);
+ int X,Y;
+ wxVTKRenderWindowInteractor *wxVTKiren;
+ wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
+ wxVTKiren->GetEventPosition(X,Y);
- int state = _model->getState();
+ int state = _view->getState();
- //Evaluate new state
- if(!_model->hasChanged() && state==CLICKED)
- {
- _model->setState(SELECTED);
- _model->setChanged();
- }
-
- if( !_model->hasChanged() && state == DRAG)
+ //Evaluate new state
+ if(_isLeftClickDown)
+ {
+ _isLeftClickDown=false;
+ if(_view->isPointInside(X,Y))
{
- _model->setState(SELECTED);
- _model->setChanged();
+ // It is supposed that I'm always inside even if the box is in drag
+ _view->setState(SELECTED);
+ _model->notifyObservers(getId());
}
-
- _model->notifyObservers();
-
}
return true;
+
}
//=========================================================================
bool GBlackBoxController::OnLeftDClick()
{
- if ( _vtkInteractorStyleBaseView!=NULL )
- {
- int X,Y;
- wxVTKRenderWindowInteractor *wxVTKiren;
- wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
- wxVTKiren->GetEventPosition(X,Y);
-
- _model->notifyObservers();
- }
+
return true;
}
//=========================================================================
- bool GBlackBoxController::OnRightButtonDown()
+ bool GBlackBoxController::OnRightButtonUp()
{
- if( _vtkInteractorStyleBaseView!= NULL )
+ GBlackBoxModel *bbmodel = (GBlackBoxModel*)_model;
+ if(bbmodel->isExecutable())
{
- int X,Y;
- wxVTKRenderWindowInteractor *wxVTKiren;
- wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
- wxVTKiren->GetEventPosition(X, Y);
-
- int state = _model->getState();
-
- //Evaluate new state
- if( !_model->hasChanged() && state == SELECTED)
- {
- _model->setState(NOTHING_HAPPENS);
- _model->setChanged();
- }
+ bbmodel->setExecutable(false);
+ }
+
+ return true;
+ }
+
+ //=========================================================================
- _model->notifyObservers();
+ bool GBlackBoxController::OnMiddleButtonDown()
+ {
+ int X,Y;
+ wxVTKRenderWindowInteractor *wxVTKiren;
+ wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
+ wxVTKiren->GetEventPosition(X,Y);
+
+ int state = _view->getState();
+
+ //Evaluate new state
+ if(_view->isPointInside(X,Y))
+ {
+ GBlackBoxModel *bbmodel = (GBlackBoxModel*)_model;
+ _view->setState(HIGHLIGHTED);
+ bbmodel->setExecutable(true);
+ bbmodel->notifyObservers(getId());
}
+
return true;
-}
+ }
//=========================================================================