#define __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
#include <cpPlugins/Interface/cpPlugins_Interface_Export.h>
+#include <cpPlugins/Interface/Config.h>
#include <cpPlugins/Interface/Object.h>
#include <cpPlugins/Interface/DataObject.h>
#include <cpPlugins/Interface/Parameters.h>
+#ifdef cpPlugins_Interface_QT4
+class QWidget;
+#else
+typedef char QWidget
+#endif // cpPlugins_Interface_QT4
+
#include <itkProcessObject.h>
+#include <vtkSmartPointer.h>
+#include <vtkAlgorithm.h>
+
namespace cpPlugins
{
namespace Interface
public:
itkTypeMacro( ProcessObject, Object );
+ cpPlugins_Id_Macro(
+ cpPlugins::Interface::ProcessObject, "BaseObject"
+ );
public:
virtual const Parameters& GetDefaultParameters( ) const;
virtual void SetNumberOfOutputs( unsigned int n );
virtual void SetInput( unsigned int idx, DataObject* dobj );
- virtual DataObject* GetOutput( unsigned int idx );
virtual std::string Update( );
virtual void DisconnectOutputs( );
- protected:
- ProcessObject( );
- virtual ~ProcessObject( );
+ virtual bool ExecConfigurationDialog( QWidget* parent );
- template< class O >
- inline void _MakeOutput( unsigned int idx );
+ template< class T >
+ inline T* GetITK( );
+
+ template< class T >
+ inline const T* GetITK( ) const;
+
+ template< class T >
+ inline T* GetVTK( );
template< class T >
- inline T* _Input( unsigned int idx );
+ inline const T* GetVTK( ) const;
template< class T >
- inline const T* _Input( unsigned int idx ) const;
+ inline T* GetInput( unsigned int idx );
template< class T >
- inline T* _Output( unsigned int idx );
+ inline const T* GetInput( unsigned int idx ) const;
template< class T >
- inline const T* _Output( unsigned int idx ) const;
+ inline T* GetOutput( unsigned int idx );
+
+ template< class T >
+ inline const T* GetOutput( unsigned int idx ) const;
+
+ protected:
+ ProcessObject( );
+ virtual ~ProcessObject( );
+
+ template< class F >
+ inline F* _CreateITK( );
+
+ template< class F >
+ inline F* _CreateVTK( );
+
+ template< class O >
+ inline void _MakeOutput( unsigned int idx );
virtual std::string _GenerateData( ) = 0;
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;