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