]> Creatis software - cpPlugins.git/blobdiff - lib/cpPlugins/Interface/DataObject.h
...
[cpPlugins.git] / lib / cpPlugins / Interface / DataObject.h
index c6a2129576e27fcb81cce76559092b06bef7ba34..cc8d8bfe60a66ce81cfce5f54d988a45f06b5912 100644 (file)
@@ -3,17 +3,21 @@
 
 #include <map>
 #include <string>
-#include <itkDataObject.h>
-#include <cpPlugins/Interface/cpPlugins_Interface_Export.h>
+#include <vtkDataObject.h>
+#include <vtkSmartPointer.h>
+#include <cpPlugins/cpPlugins_Export.h>
 #include <cpPlugins/Interface/Object.h>
 
+#define ITK_MANUAL_INSTANTIATION
+#include <itkDataObject.h>
+
 namespace cpPlugins
 {
   namespace Interface
   {
     /**
      */
-    class cpPlugins_Interface_EXPORT DataObject
+    class cpPlugins_EXPORT DataObject
       : public Object
     {
     public:
@@ -23,15 +27,16 @@ namespace cpPlugins
       typedef itk::SmartPointer< const Self > ConstPointer;
 
     public:
-      itkNewMacro( Self );
       itkTypeMacro( DataObject, Object );
 
     public:
-      virtual std::string GetClassName( ) const;
-      virtual std::string GetClassType( ) const;
+      virtual itk::DataObject* GetITKDataObject( );
+      virtual const itk::DataObject* GetITKDataObject( ) const;
+      virtual void SetITKDataObject( itk::DataObject* o ) = 0;
 
-      itk::DataObject* GetRealDataObject( ) const;
-      virtual void SetRealDataObject( itk::DataObject* dobj );
+      virtual vtkDataObject* GetVTKDataObject( );
+      virtual const vtkDataObject* GetVTKDataObject( ) const;
+      virtual void SetVTKDataObject( vtkDataObject* o ) = 0;
 
       Object* GetSource( );
       const Object* GetSource( ) const;
@@ -49,8 +54,9 @@ namespace cpPlugins
       Self& operator=( const Self& );
 
     protected:
-      itk::DataObject::Pointer m_RealDataObject;
-      Object::Pointer          m_Source;
+      itk::DataObject::Pointer         m_ITKObject;
+      vtkSmartPointer< vtkDataObject > m_VTKObject;
+      Object::Pointer                  m_Source;
     };
 
   } // ecapseman