]> Creatis software - cpPlugins.git/blobdiff - lib/cpPlugins/Interface/DataObject.cxx
Widget integration (step 3/6).
[cpPlugins.git] / lib / cpPlugins / Interface / DataObject.cxx
index 4ec6223b6096d995f662b45e276311ae598035f7..536ea811fdeb90c8b124a199f71bdb908a1981d2 100644 (file)
@@ -1,52 +1,83 @@
 #include <cpPlugins/Interface/DataObject.h>
 
-// -------------------------------------------------------------------------
-cpPlugins::Interface::DataObject::
-DataObject( )
-  : Superclass( ),
-    m_Source( NULL )
-{
-}
+#include <itkDataObject.h>
+#include <vtkImageData.h>
+#include <vtkPolyData.h>
 
 // -------------------------------------------------------------------------
-cpPlugins::Interface::DataObject::
-~DataObject( )
+cpPlugins::Interface::Object* cpPlugins::Interface::DataObject::
+GetSource( )
 {
+  return( this->m_Source );
 }
 
 // -------------------------------------------------------------------------
-std::string cpPlugins::Interface::DataObject::
-GetClassName( ) const
+const cpPlugins::Interface::Object* cpPlugins::Interface::DataObject::
+GetSource( ) const
 {
-  return( "cpPlugins::Interface::DataObject" );
+  return( this->m_Source );
 }
 
 // -------------------------------------------------------------------------
-itk::DataObject* cpPlugins::Interface::DataObject::
-GetDataObject( ) const
+void cpPlugins::Interface::DataObject::
+SetSource( cpPlugins::Interface::Object* src )
 {
-  return( this->m_DataObject );
+  if( this->m_Source.GetPointer( ) != src )
+  {
+    this->m_Source = src;
+    this->Modified( );
+
+  } // fi
 }
 
 // -------------------------------------------------------------------------
 void cpPlugins::Interface::DataObject::
-SetDataObject( itk::DataObject* dobj )
+DisconnectPipeline( )
 {
-  this->m_DataObject = dobj;
+  // Disconnect input pipelines (ITK)
+  itk::DataObject* itk_obj = this->GetITK< itk::DataObject >( );
+  if( itk_obj != NULL )
+    itk_obj->DisconnectPipeline( );
+
+  // Disconnect input pipelines (VTK)
+  vtkImageData* vtk_image = this->GetVTK< vtkImageData >( );
+  vtkPolyData* vtk_pd = this->GetVTK< vtkPolyData >( );
+  if( vtk_image != NULL )
+  {
+    vtkSmartPointer< vtkImageData > d =
+      vtkSmartPointer< vtkImageData >::New( );
+    d->ShallowCopy( vtk_image );
+    this->m_VTKObject = d;
+  }
+  else if( vtk_pd != NULL )
+  {
+    vtkSmartPointer< vtkPolyData > d =
+      vtkSmartPointer< vtkPolyData >::New( );
+    d->ShallowCopy( vtk_pd );
+    this->m_VTKObject = d;
+
+  } // fi
+
+  // Unbind source
+  this->m_Source = NULL;
 }
 
 // -------------------------------------------------------------------------
-cpPlugins::Interface::ProcessObject* cpPlugins::Interface::DataObject::
-GetSource( ) const
+cpPlugins::Interface::DataObject::
+DataObject( )
+  : Superclass( ),
+    m_ITKObject( NULL ),
+    m_VTKObject( NULL ),
+    m_Source( NULL )
 {
-  return( this->m_Source );
+  this->m_ClassName = "cpPlugins::Interface::DataObject";
+  this->m_ClassCategory = "BasicObject";
 }
 
 // -------------------------------------------------------------------------
-void cpPlugins::Interface::DataObject::
-SetSource( cpPlugins::Interface::ProcessObject* src )
+cpPlugins::Interface::DataObject::
+~DataObject( )
 {
-  this->m_Source = src;
 }
 
 // eof - $RCSfile$