1 #include <cpPlugins/Plugins/RGBImageToHSVChannelsFilter.h>
2 #include <cpPlugins/Interface/Image.h>
3 #include <cpPlugins/Extensions/Algorithms/RGBImageToHSVChannelsFilter.h>
5 #define ITK_MANUAL_INSTANTIATION
7 #include <itkRGBPixel.h>
9 // -------------------------------------------------------------------------
10 #define cpPlugins_RGBImageToHSVChannelsFilter_Dimension( r, d, o, f ) \
11 if( dynamic_cast< itk::ImageBase< d >* >( o ) != NULL ) \
14 // -------------------------------------------------------------------------
15 #define cpPlugins_RGBImageToHSVChannelsFilter_RGB( r, p, d, o, f ) \
17 dynamic_cast< itk::Image< itk::RGBPixel< p >, d >* >( o ) != NULL \
19 r = this->f< p, d >( )
21 // -------------------------------------------------------------------------
22 cpPlugins::Plugins::RGBImageToHSVChannelsFilter::
23 RGBImageToHSVChannelsFilter( )
26 this->SetNumberOfInputs( 1 );
27 this->SetNumberOfOutputs( 3 );
28 this->_MakeOutput< cpPlugins::Interface::Image >( 0 );
29 this->_MakeOutput< cpPlugins::Interface::Image >( 1 );
30 this->_MakeOutput< cpPlugins::Interface::Image >( 2 );
32 this->m_DefaultParameters.clear( );
35 // -------------------------------------------------------------------------
36 cpPlugins::Plugins::RGBImageToHSVChannelsFilter::
37 ~RGBImageToHSVChannelsFilter( )
41 // -------------------------------------------------------------------------
42 std::string cpPlugins::Plugins::RGBImageToHSVChannelsFilter::
45 return( "cpPlugins::Plugins::RGBImageToHSVChannelsFilter" );
48 // -------------------------------------------------------------------------
49 std::string cpPlugins::Plugins::RGBImageToHSVChannelsFilter::
52 itk::DataObject* o = this->_GetInput( 0 );
54 std::string r = "cpPlugins::Plugins::RGBImageToHSVChannelsFilter: itk::Image dimension not supported.";
55 cpPlugins_RGBImageToHSVChannelsFilter_Dimension( r, 1, o, _GD0 );
56 else cpPlugins_RGBImageToHSVChannelsFilter_Dimension( r, 2, o, _GD0 );
57 else cpPlugins_RGBImageToHSVChannelsFilter_Dimension( r, 3, o, _GD0 );
58 else cpPlugins_RGBImageToHSVChannelsFilter_Dimension( r, 4, o, _GD0 );
62 // -------------------------------------------------------------------------
63 template< unsigned int D >
64 std::string cpPlugins::Plugins::RGBImageToHSVChannelsFilter::
67 itk::ImageBase< D >* i =
68 dynamic_cast< itk::ImageBase< D >* >( this->_GetInput( 0 ) );
70 std::string r = "cpPlugins::Plugins::RGBImageToHSVChannelsFilter: itk::Image pixel type not supported";
71 cpPlugins_RGBImageToHSVChannelsFilter_RGB( r, char, D, i, _GD1 );
72 else cpPlugins_RGBImageToHSVChannelsFilter_RGB( r, short, D, i, _GD1 );
73 else cpPlugins_RGBImageToHSVChannelsFilter_RGB( r, int, D, i, _GD1 );
74 else cpPlugins_RGBImageToHSVChannelsFilter_RGB( r, long, D, i, _GD1 );
75 else cpPlugins_RGBImageToHSVChannelsFilter_RGB( r, unsigned char, D, i, _GD1 );
76 else cpPlugins_RGBImageToHSVChannelsFilter_RGB( r, unsigned short, D, i, _GD1 );
77 else cpPlugins_RGBImageToHSVChannelsFilter_RGB( r, unsigned int, D, i, _GD1 );
78 else cpPlugins_RGBImageToHSVChannelsFilter_RGB( r, unsigned long, D, i, _GD1 );
79 else cpPlugins_RGBImageToHSVChannelsFilter_RGB( r, float, D, i, _GD1 );
80 else cpPlugins_RGBImageToHSVChannelsFilter_RGB( r, double, D, i, _GD1 );
84 // -------------------------------------------------------------------------
85 template< class P, unsigned int D >
86 std::string cpPlugins::Plugins::RGBImageToHSVChannelsFilter::
89 typedef itk::Image< itk::RGBPixel< P >, D > _TImage;
90 typedef itk::Image< P, D > _TChannel;
91 typedef cpPlugins::Extensions::Algorithms::
92 RGBImageToHSVChannelsFilter< _TImage, _TChannel > _TFilter;
96 dynamic_cast< _TFilter* >( this->m_Filter.GetPointer( ) );
99 this->m_Filter = _TFilter::New( );
100 filter = dynamic_cast< _TFilter* >( this->m_Filter.GetPointer( ) );
103 filter->SetInput( dynamic_cast< _TImage* >( this->_GetInput( 0 ) ) );
106 this->_SetOutput( 0, filter->GetHueOutput( ) );
107 this->_SetOutput( 1, filter->GetSaturationOutput( ) );
108 this->_SetOutput( 2, filter->GetValueOutput( ) );