]> Creatis software - bbtkGEditor.git/blobdiff - lib/EditorGraphicBBS/bbsVtkGUIEditorGraphic/GObjectController.cxx
Organizing code, the state now is in the view and the general render was simplified...
[bbtkGEditor.git] / lib / EditorGraphicBBS / bbsVtkGUIEditorGraphic / GObjectController.cxx
index 6b1174ff43faa6425f71f49d1a29e053ceaa1fbc..0dffa0ec1a4d4d929ca092bde21663c4445e8e50 100644 (file)
@@ -47,9 +47,11 @@ namespace bbtk
        }
 
        //=========================================================================
+       
        GObjectController::~GObjectController()
        {
        }
+
        //=========================================================================
 
        void GObjectController::setModelAndView(GObjectModel* model, vtkGObjectView* view)
@@ -57,183 +59,228 @@ namespace bbtk
                _model = model;
                _view = view;
        }
-       //=========================================================================
 
-bool GObjectController::OnMouseMove()
-{
-       
-       /**********************   VIRTUAL *************************/
+       //=========================================================================
 
-       if ( _vtkInteractorStyleBaseView!=NULL)
+       bool GObjectController::OnMouseMove()
        {
-               int X,Y;
-               wxVTKRenderWindowInteractor *_wxVTKiren;
-               _wxVTKiren= _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
-               _wxVTKiren->GetEventPosition( X , Y );
-
-               int state  = _model->getState();
                
-               //Evaluate new state
-               if(!_model->hasChanged() && state == DRAG)
-               {
-                       moveObject(X,Y);
-                       _model->setChanged();
-               }
+               /**********************   VIRTUAL *************************/
 
-               if(!_model->hasChanged() && state == NOTHING_HAPPENS)
-               {
-                       if(_view->isPointInside(X,Y))
-                       {
-                               _model->setState(HIGHLIGHTED);
-                               _model->setChanged();                           
-                       }                       
-               }
-               if(!_model->hasChanged() && state==HIGHLIGHTED)
+               if ( _vtkInteractorStyleBaseView!=NULL)
                {
-                       if(!_view->isPointInside(X,Y))
+                       int X,Y;
+                       wxVTKRenderWindowInteractor *_wxVTKiren;
+                       _wxVTKiren= _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
+                       _wxVTKiren->GetEventPosition( X , Y );
+
+                       int state  = _view->getState();
+                       
+                       //Evaluate new state
+                       if(!_model->hasChanged() && state == DRAG)
                        {
-                               _model->setState(NOTHING_HAPPENS);
+                               moveObject(X,Y);
                                _model->setChanged();
                        }
+
+                       if(!_model->hasChanged() && state == NOTHING_HAPPENS)
+                       {
+                               if(_view->isPointInside(X,Y))
+                               {
+                                       _view->setState(HIGHLIGHTED);
+                                       _model->setChanged();                           
+                               }                       
+                       }
+                       if(!_model->hasChanged() && state==HIGHLIGHTED)
+                       {
+                               if(!_view->isPointInside(X,Y))
+                               {
+                                       _view->setState(NOTHING_HAPPENS);
+                                       _model->setChanged();
+                               }
+                       }
+                       
+                       _model->notifyObservers(_id);
+                       
                }
-               
-               _model->notifyObservers();
-       }
 
-       /**/
+               /**/
 
-       return true;
-}
-//=========================================================================
-bool GObjectController::OnLeftButtonDown()
-{
-       /**********************   VIRTUAL *************************
+               return true;
+       }
+
+       //=========================================================================
        
-       if ( _vtkInteractorStyleBaseView!=NULL )
+       bool GObjectController::OnLeftButtonDown()
        {
-               int X,Y;
-               wxVTKRenderWindowInteractor *wxVTKiren;
-               wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
-               wxVTKiren->GetEventPosition(X,Y);
-
-               int state  = _model->getState();
+               /**********************   VIRTUAL *************************
                
-               //Evaluate new state
-               if(!_model->hasChanged() && state==HIGHLIGHTED)
-               {
-                       _view->isStartDragging(true);
-                       _model->setState(DRAG);
-                       _model->setChanged();
-               }
-
-               if( !_model->hasChanged() && state == SELECTED)
+               if ( _vtkInteractorStyleBaseView!=NULL )
                {
-                       if(_view->isPointInside(X,Y))
+                       int X,Y;
+                       wxVTKRenderWindowInteractor *wxVTKiren;
+                       wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
+                       wxVTKiren->GetEventPosition(X,Y);
+
+                       int state  = _model->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();
                }
-               
-               _model->notifyObservers();
+
+               */
+
+               return true;
        }
 
-       */
+       //=========================================================================
+       
+       bool GObjectController::OnLeftButtonUp()
+       {
 
-       return true;
-}
-//=========================================================================
-bool GObjectController::OnLeftButtonUp()
-{
+               /**********************   VIRTUAL *************************
+
+               if ( _vtkInteractorStyleBaseView!=NULL )
+               {
+                       int X,Y;
+                       wxVTKRenderWindowInteractor *wxVTKiren;
+                       wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
+                       wxVTKiren->GetEventPosition(X,Y);
+
+                       int state  = _model->getState();
+                       
+                       //Evaluate new state
+                       if(!_model->hasChanged() && state==CLICKED)
+                       {
+                               _model->setState(SELECTED);
+                               _model->setChanged();
+                       }
+
+                       if( !_model->hasChanged() && state == DRAG)
+                       {
+                               _model->setState(SELECTED);
+                               _model->setChanged();
+                       }
+
+                       _model->notifyObservers();
+
+               }
 
-       /**********************   VIRTUAL *************************
+               */
+               return true;
+       }
 
-       if ( _vtkInteractorStyleBaseView!=NULL )
+       //=========================================================================
+       
+       bool GObjectController::OnLeftDClick()
        {
-               int X,Y;
-               wxVTKRenderWindowInteractor *wxVTKiren;
-               wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
-               wxVTKiren->GetEventPosition(X,Y);
+               /**********************   VIRTUAL *************************
 
-               int state  = _model->getState();
-               
-               //Evaluate new state
-               if(!_model->hasChanged() && state==CLICKED)
+               if ( _vtkInteractorStyleBaseView!=NULL )
                {
-                       _model->setState(SELECTED);
-                       _model->setChanged();
+                       int X,Y;
+                       wxVTKRenderWindowInteractor *wxVTKiren;
+                       wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
+                       wxVTKiren->GetEventPosition(X,Y);
+
+                       _model->notifyObservers();
                }
 
-               if( !_model->hasChanged() && state == DRAG)
+               */
+               return true;
+       }
+
+       //=========================================================================
+
+       bool GObjectController::OnRightButtonDown()
+       {
+               /**********************   VIRTUAL *************************/
+
+               if( _vtkInteractorStyleBaseView!= NULL )
                {
-                       _model->setState(SELECTED);
-                       _model->setChanged();
+                       int X,Y;
+                       wxVTKRenderWindowInteractor *wxVTKiren;
+                       wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
+                       wxVTKiren->GetEventPosition(X, Y);
+                       
+                       int state  = _view->getState();
+                       
+                       //Evaluate new state
+                       if( !_model->hasChanged() && state == SELECTED)
+                       {
+                               _view->setState(NOTHING_HAPPENS);
+                               _model->setChanged();                   
+                       }
+
+                       _model->notifyObservers(_id);
                }
+               
+               /**/
 
-               _model->notifyObservers();
+               return true;
 
        }
 
-       */
-       return true;
-}
-//=========================================================================
-bool GObjectController::OnLeftDClick()
-{
-       /**********************   VIRTUAL *************************
+       //=========================================================================
 
-       if ( _vtkInteractorStyleBaseView!=NULL )
+       void GObjectController::moveObject(int X,int Y)
        {
-               int X,Y;
-               wxVTKRenderWindowInteractor *wxVTKiren;
-               wxVTKiren = _vtkInteractorStyleBaseView->GetWxVtk3DBaseView()->GetWxVTKRenderWindowInteractor();
-               wxVTKiren->GetEventPosition(X,Y);
-
-               _model->notifyObservers();
+               _view->moveObject(X,Y); 
        }
 
-       */
-       return true;
-}
-//=========================================================================
-bool GObjectController::OnRightButtonDown()
-{
-       /**********************   VIRTUAL *************************/
+       //=========================================================================
 
-       if( _vtkInteractorStyleBaseView!= NULL )
+       int GObjectController::getGObjectType()
        {
-               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();                   
-               }
-
-               _model->notifyObservers();
+               return _model->getGObjectType();
        }
+
+       //=========================================================================
        
-       /**/
+       GObjectModel* GObjectController::getModel()
+       {
+               return _model;
+       }
 
-       return true;
+       //=========================================================================
 
-}
+       vtkGObjectView* GObjectController::getView()
+       {
+               return _view;
+       }
 
-//=========================================================================
+       //=========================================================================
 
-void GObjectController::moveObject(int X,int Y)
-{
-       _view->moveObject(X,Y); 
-}
+       int GObjectController::getId()
+       {
+               return _id;
+       }
 
-//=========================================================================
+       //=========================================================================
+       
+       void GObjectController::setId(int id)
+       {
+               _id = id;
+       }
+
+       //=========================================================================
 
 }  // EO namespace bbtk