]> Creatis software - cpPlugins.git/blob - lib/cpPlugins/Interface/ProcessObject.h
New plugins added
[cpPlugins.git] / lib / cpPlugins / Interface / ProcessObject.h
1 #ifndef __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
2 #define __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
3
4 #include <map>
5 #include <string>
6 #include <itkDataObject.h>
7 #include <itkProcessObject.h>
8 #include <cpPlugins/Interface/cpPlugins_Interface_Export.h>
9 #include <cpPlugins/Interface/Object.h>
10 #include <cpPlugins/Interface/DataObject.h>
11
12 namespace cpPlugins
13 {
14   namespace Interface
15   {
16     class DataObject;
17
18     /**
19      */
20     class cpPlugins_Interface_EXPORT ProcessObject
21       : public Object
22     {
23     public:
24       typedef ProcessObject Self;
25       typedef Object        Superclass;
26
27       typedef std::pair< std::string, std::string > TParameter;
28       typedef std::map< std::string, TParameter >   TParameters;
29
30     public:
31       ProcessObject( );
32       virtual ~ProcessObject( );
33
34       virtual std::string GetClassName( ) const;
35       virtual const TParameters& GetDefaultParameters( ) const;
36       virtual void SetParameters( const TParameters& params );
37
38       virtual unsigned int GetNumberOfInputs( ) const;
39       virtual unsigned int GetNumberOfOutputs( ) const;
40
41       virtual void SetNumberOfInputs( unsigned int n );
42       virtual void SetNumberOfOutputs( unsigned int n );
43
44       virtual void SetInput( unsigned int idx, const DataObject* dobj );
45       virtual DataObject* GetOutput( unsigned int idx );
46
47       virtual std::string Update( );
48       virtual void DisconnectOutputs( );
49
50     protected:
51       virtual itk::DataObject* _GetInput( unsigned int idx );
52       virtual void _SetOutput( unsigned int idx, itk::DataObject* dobj );
53       virtual void _DeleteOutputs( );
54
55       template< class O >
56       void _MakeOutput( unsigned int idx )
57         {
58           if( idx >= this->m_Outputs.size( ) )
59             return;
60         
61           if( !( this->m_OutputsDisconnected ) )
62             if( this->m_Outputs[ idx ] != NULL )
63               delete this->m_Outputs[ idx ];
64
65           this->m_Outputs[ idx ] = new O( );
66           this->m_Outputs[ idx ]->SetSource( this );
67         }
68
69       virtual std::string _GenerateData( ) = 0;
70
71     protected:
72       TParameters m_DefaultParameters;
73       TParameters m_Parameters;
74
75       std::vector< const DataObject* > m_Inputs;
76       std::vector< DataObject* >       m_Outputs;
77       bool m_OutputsDisconnected;
78     };
79
80   } // ecapseman
81
82 } // ecapseman
83
84 #endif // __CPPLUGINS__INTERFACE__PROCESSOBJECT__H__
85
86 // eof - $RCSfile$