#include <itkProcessObject.h>
-class vtkAlgorithm;
+#include <vtkSmartPointer.h>
+#include <vtkAlgorithm.h>
namespace cpPlugins
{
itkTypeMacro( ProcessObject, Object );
public:
- virtual vtkAlgorithm* GetVTKAlgorithm( )
- { return( NULL ); }
- virtual const vtkAlgorithm* GetVTKAlgorithm( ) const
- { return( NULL ); }
-
virtual const Parameters& GetDefaultParameters( ) const;
virtual void SetParameters( const Parameters& params );
virtual bool ExecConfigurationDialog( QWidget* parent );
+ template< class T >
+ inline T* GetITK( );
+
+ template< class T >
+ inline const T* GetITK( ) const;
+
+ template< class T >
+ inline T* GetVTK( );
+
+ template< class T >
+ inline const T* GetVTK( ) const;
+
template< class T >
inline T* GetInput( unsigned int idx );
ProcessObject( );
virtual ~ProcessObject( );
+ template< class F >
+ inline F* _CreateITK( );
+
+ template< class F >
+ inline F* _CreateVTK( );
+
template< class O >
inline void _MakeOutput( unsigned int idx );
Self& operator=( const Self& );
protected:
- itk::ProcessObject::Pointer m_RealProcessObject;
+ itk::ProcessObject::Pointer m_ITKObject;
+ vtkSmartPointer< vtkAlgorithm > m_VTKObject;
+
Parameters m_DefaultParameters;
Parameters m_Parameters;