#include <cpPlugins/Interface/DataObject.h>
+#include <vtkImageData.h>
+#include <vtkPolyData.h>
// -------------------------------------------------------------------------
-cpPlugins::Interface::DataObject::
-DataObject( )
- : Superclass( ),
- m_Source( NULL )
+itk::DataObject* cpPlugins::Interface::DataObject::
+GetITKDataObject( )
{
+ return( this->m_ITKObject.GetPointer( ) );
}
// -------------------------------------------------------------------------
-cpPlugins::Interface::DataObject::
-~DataObject( )
+const itk::DataObject* cpPlugins::Interface::DataObject::
+GetITKDataObject( ) const
{
+ return( this->m_ITKObject.GetPointer( ) );
}
// -------------------------------------------------------------------------
-std::string cpPlugins::Interface::DataObject::
-GetClassName( ) const
+vtkDataObject* cpPlugins::Interface::DataObject::
+GetVTKDataObject( )
{
- return( "cpPlugins::Interface::DataObject" );
+ return( this->m_VTKObject.GetPointer( ) );
}
// -------------------------------------------------------------------------
-itk::DataObject* cpPlugins::Interface::DataObject::
-GetDataObject( ) const
+const vtkDataObject* cpPlugins::Interface::DataObject::
+GetVTKDataObject( ) const
{
- return( this->m_DataObject );
+ return( this->m_VTKObject.GetPointer( ) );
}
// -------------------------------------------------------------------------
-void cpPlugins::Interface::DataObject::
-SetDataObject( itk::DataObject* src )
+cpPlugins::Interface::Object* cpPlugins::Interface::DataObject::
+GetSource( )
{
- this->m_DataObject = src;
+ return( this->m_Source );
}
// -------------------------------------------------------------------------
-cpPlugins::Interface::ProcessObject* cpPlugins::Interface::DataObject::
+const cpPlugins::Interface::Object* cpPlugins::Interface::DataObject::
GetSource( ) const
{
return( this->m_Source );
// -------------------------------------------------------------------------
void cpPlugins::Interface::DataObject::
-SetSource( cpPlugins::Interface::ProcessObject* src )
+SetSource( cpPlugins::Interface::Object* src )
+{
+ if( this->m_Source.GetPointer( ) != src )
+ {
+ this->m_Source = src;
+ this->Modified( );
+
+ } // fi
+}
+
+// -------------------------------------------------------------------------
+void cpPlugins::Interface::DataObject::
+DisconnectPipeline( )
+{
+ if( this->m_ITKObject.IsNotNull( ) )
+ {
+ // Disconnect input pipelines
+ this->m_ITKObject->DisconnectPipeline( );
+ vtkImageData* vtk_image =
+ dynamic_cast< vtkImageData* >( this->m_VTKObject.GetPointer( ) );
+ vtkPolyData* vtk_pd =
+ dynamic_cast< vtkPolyData* >( this->m_VTKObject.GetPointer( ) );
+ 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
+ if( this->m_Source.IsNotNull( ) )
+ this->m_Source->Delete( );
+ this->Register( );
+
+ } // fi
+}
+
+// -------------------------------------------------------------------------
+cpPlugins::Interface::DataObject::
+DataObject( )
+ : Superclass( )
+{
+ this->m_ClassName = "cpPlugins::Interface::DataObject";
+ this->m_ClassCategory = "BasicObject";
+}
+
+// -------------------------------------------------------------------------
+cpPlugins::Interface::DataObject::
+~DataObject( )
{
- this->m_Source = src;
}
// eof - $RCSfile$