]> Creatis software - bbtkGEditor.git/blobdiff - lib/EditorGraphicBBS/bbsVtkGUIEditorGraphic/vtkGObjectView.cxx
Important change in the project to visualize the contour when the output was selected...
[bbtkGEditor.git] / lib / EditorGraphicBBS / bbsVtkGUIEditorGraphic / vtkGObjectView.cxx
index 5e322e1a765160ad5e44e2202d9f0f4a9946f2cd..98cfc8584b1204378b2aa597ad1ce28a583bf03e 100644 (file)
@@ -45,6 +45,7 @@ namespace bbtk
        {
                _baseView=NULL;
                _objectActor=NULL;
+               _isFirstDragging=false;
        }
 
        //=========================================================================
@@ -53,19 +54,9 @@ namespace bbtk
        }
        //=========================================================================
 
-       void vtkGObjectView::refresh()
+       void vtkGObjectView::update(int command)//virtual
        {
-               if(_model->getState()==NOTHING_HAPPENS)
-               {
-                       _objectActor->GetProperty()->SetColor(0,0,0);
-               }
-
-               if(_model->getState()==HIGHLIGHTED)
-               {
-                       _objectActor->GetProperty()->SetColor(1,0,0);
-               }
-               _baseView->GetRenderer()->Render();
-               //paint();
+               //virtual
        }
 
        //=========================================================================
@@ -107,15 +98,49 @@ namespace bbtk
 
        //=========================================================================
 
-       bool vtkGObjectView::isPointInside(int X,int Y) 
+       bool vtkGObjectView::isPointInside(int X,int Y) //virtual
        {
-               double xx=X,yy=Y,zz=0;
+               // RaC In the actual version, always z=900
+               double xx=X,yy=Y,zz=900;
                _baseView->TransCoordScreenToWorld(xx,yy,zz);
                return _model->isPointInside(xx,yy,zz);
        }
 
        //=========================================================================
 
+       void vtkGObjectView::moveObject(int X,int Y) //virtual
+       {               
+               // RaC In the actual version, always z=900
+               double xx=X,yy=Y,zz=900;
+               _baseView->TransCoordScreenToWorld(xx,yy,zz);
+
+               
+
+               if(_isFirstDragging)
+               {
+                       _isFirstDragging=false;
+                       
+                       double xInic,yInic,zInic;
+                       _model->getInicPoint(xInic,yInic,zInic);                        
+                       dragDifX=xx-xInic;
+                       dragDifY=yy-yInic;      
+               }
+
+               _model->move(xx-dragDifX,yy-dragDifY,zz);
+
+       }
+
+       //=========================================================================
+
+       void vtkGObjectView::isFirstDragging(bool param)
+       {
+               _isFirstDragging=param;
+               dragDifX=0;
+               dragDifX=0;
+       }
+
+       //=========================================================================
+
 }  // EO namespace bbtk
 
 // EOF