#ifndef __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
#define __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
-#include <map>
-#include <string>
-#include <itkProcessObject.h>
-#include <cpPlugins/Interface/cpPlugins_Interface_Export.h>
-#include <cpPlugins/Interface/Object.h>
+#include <set>
+
#include <cpPlugins/Interface/DataObject.h>
+#include <cpPlugins/Interface/Parameters.h>
+
+#include <itkProcessObject.h>
+#include <vtkSmartPointer.h>
+#include <vtkAlgorithm.h>
+
+// Some forward declarations
+class vtkRenderWindowInteractor;
+#ifdef cpPlugins_Interface_QT4
+class QWidget;
+#else
+typedef char QWidget;
+#endif // cpPlugins_Interface_QT4
namespace cpPlugins
{
namespace Interface
{
+ // Some forward declarations
+ class Plugins;
+#ifdef cpPlugins_Interface_QT4
+ class ParametersQtDialog;
+#else
+ typedef char ParametersQtDialog;
+#endif // cpPlugins_Interface_QT4
+
/**
*/
class cpPlugins_Interface_EXPORT ProcessObject
typedef itk::SmartPointer< Self > Pointer;
typedef itk::SmartPointer< const Self > ConstPointer;
- typedef std::pair< std::string, std::string > TParameter;
- typedef std::map< std::string, TParameter > TParameters;
+ typedef Parameters TParameters;
+ typedef std::set< vtkRenderWindowInteractor* > TInteractors;
+
+ enum DialogResult
+ {
+ DialogResult_NoModal = 0,
+ DialogResult_Modal,
+ DialogResult_Cancel
+ };
public:
itkTypeMacro( ProcessObject, Object );
+ cpPlugins_Id_Macro( ProcessObject, "BaseObject" );
+
+ itkBooleanMacro( Interactive );
+
+ itkGetConstObjectMacro( Parameters, TParameters );
+ itkGetObjectMacro( Parameters, TParameters );
+ itkGetConstMacro( Plugins, const Plugins* );
+ itkGetMacro( Plugins, Plugins* );
+ itkGetConstMacro( Interactive, bool );
+
+ itkSetObjectMacro( Plugins, Plugins );
+ itkSetMacro( Interactive, bool );
public:
- virtual std::string GetClassName( ) const;
- virtual std::string GetClassType( ) const;
- virtual const TParameters& GetDefaultParameters( ) const;
- virtual void SetParameters( const TParameters& params );
+ // To impact pipeline
+ virtual void Modified( ) const;
- virtual unsigned int GetNumberOfInputs( ) const;
- virtual unsigned int GetNumberOfOutputs( ) const;
+ virtual void GetInputsNames( std::set< std::string >& names ) const;
+ virtual void GetOutputsNames( std::set< std::string >& names ) const;
- virtual void SetNumberOfInputs( unsigned int n );
- virtual void SetNumberOfOutputs( unsigned int n );
+ virtual bool SetOutputObjectName(
+ const std::string& new_object_name,
+ const std::string& output_name
+ );
- virtual void SetInput( unsigned int idx, DataObject* dobj );
- virtual DataObject* GetOutput( unsigned int idx );
+ virtual void SetInput( const std::string& id, DataObject* dobj );
virtual std::string Update( );
virtual void DisconnectOutputs( );
+ virtual void AddInteractor( vtkRenderWindowInteractor* interactor );
+ virtual DialogResult 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( const std::string& id );
+
+ template< class T >
+ inline const T* GetInput( const std::string& id ) const;
+
+ template< class T >
+ inline T* GetOutput( const std::string& id );
+
+ template< class T >
+ inline const T* GetOutput( const std::string& id ) const;
+
protected:
ProcessObject( );
virtual ~ProcessObject( );
- virtual itk::DataObject* _GetInput( unsigned int idx );
- virtual void _SetOutput( unsigned int idx, itk::DataObject* dobj );
+ virtual void _AddInput( const std::string& name );
+
+ template< class F >
+ inline F* _CreateITK( );
+
+ template< class F >
+ inline F* _CreateVTK( );
template< class O >
- void _MakeOutput( unsigned int idx )
- {
- if( idx >= this->m_Outputs.size( ) )
- return;
- this->m_Outputs[ idx ] = O::New( );
- this->m_Outputs[ idx ]->SetSource( this );
- }
+ inline void _MakeOutput( const std::string& id );
virtual std::string _GenerateData( ) = 0;
Self& operator=( const Self& );
protected:
- itk::ProcessObject::Pointer m_RealProcessObject;
- TParameters m_DefaultParameters;
- TParameters m_Parameters;
-
- std::vector< DataObject::Pointer > m_Inputs;
- std::vector< DataObject::Pointer > m_Outputs;
+ itk::ProcessObject::Pointer m_ITKObject;
+ vtkSmartPointer< vtkAlgorithm > m_VTKObject;
+
+ Parameters::Pointer m_Parameters;
+ ParametersQtDialog* m_ParametersDialog;
+ TInteractors m_Interactors;
+ Plugins* m_Plugins;
+ bool m_Interactive;
+
+ typedef std::map< std::string, DataObject::Pointer > _TDataContainer;
+ _TDataContainer m_Inputs;
+ _TDataContainer m_Outputs;
+ std::map< std::string, std::string > m_OutputObjectsNames;
};
+ /**
+ * Plugin provider
+ */
+ CPPLUGINS_PROVIDER_HEADER( ProcessObject );
+
} // ecapseman
} // ecapseman
+#include <cpPlugins/Interface/ProcessObject.hxx>
+
#endif // __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
// eof - $RCSfile$