]> Creatis software - cpPlugins.git/blobdiff - lib/cpExtensions/Visualization/SkeletonToPolyData.h
yet another refactoring
[cpPlugins.git] / lib / cpExtensions / Visualization / SkeletonToPolyData.h
diff --git a/lib/cpExtensions/Visualization/SkeletonToPolyData.h b/lib/cpExtensions/Visualization/SkeletonToPolyData.h
new file mode 100644 (file)
index 0000000..1cef407
--- /dev/null
@@ -0,0 +1,60 @@
+#ifndef __cpExtensions__Visualization__SkeletonToPolyData__h__
+#define __cpExtensions__Visualization__SkeletonToPolyData__h__
+
+#include <cpExtensions/Config.h>
+#include <vtkPolyDataAlgorithm.h>
+
+namespace cpExtensions
+{
+  namespace Visualization
+  {
+    /**
+     */
+    template< class _TSkeleton >
+    class cpExtensions_EXPORT SkeletonToPolyData
+      : public vtkPolyDataAlgorithm
+    {
+    public:
+      typedef SkeletonToPolyData Self;
+      typedef _TSkeleton TSkeleton;
+
+    public:
+      vtkTypeMacro( SkeletonToPolyData, vtkPolyDataAlgorithm );
+
+    public:
+      static Self* New( );
+
+      const TSkeleton* GetInput( ) const;
+      void SetInput( const TSkeleton* sk );
+
+    protected:
+      SkeletonToPolyData( );
+      virtual ~SkeletonToPolyData( );
+
+      int RequestData(
+        vtkInformation* information,
+        vtkInformationVector** input,
+        vtkInformationVector* output
+        );
+      int RequestInformation(
+        vtkInformation* information,
+        vtkInformationVector** input,
+        vtkInformationVector* output
+        );
+
+    private:
+      // Purposely not implemented
+      SkeletonToPolyData( const Self& );
+      void operator=( const Self& );
+
+    protected:
+      const TSkeleton* m_Skeleton;
+    };
+
+  } // ecapseman
+
+} // ecapseman
+
+#endif //  __cpExtensions__Visualization__SkeletonToPolyData__h__
+
+// eof - $RCSfile$