]> Creatis software - cpPlugins.git/blobdiff - plugins/ImageArithmeticFilters/PowImageFilter.cxx
...
[cpPlugins.git] / plugins / ImageArithmeticFilters / PowImageFilter.cxx
index f0b4c8e09feb8cb8f0cdbd3a4097e347659d6626..62c2a8561168f12fb0faf83640aa222fe379d39d 100644 (file)
@@ -1,17 +1,18 @@
-#include <plugins/ImageArithmeticFilters/PowImageFilter.h>
+#include <ImageArithmeticFilters/PowImageFilter.h>
 #include <cpPlugins/DataObjects/Image.h>
+#include <cpPlugins/DataObjects/Image_Demanglers.h>
 
 #include <itkPowImageFilter.h>
-#include <itkBinaryFunctorImageFilter.hxx>
 
 // -------------------------------------------------------------------------
 cpPluginsImageArithmeticFilters::PowImageFilter::
 PowImageFilter( )
   : Superclass( )
 {
-  this->_ConfigureInput< cpPlugins::DataObjects::Image >( "Input0", true, false );
-  this->_ConfigureInput< cpPlugins::DataObjects::Image >( "Input1", false, false );
-  this->_ConfigureOutput< cpPlugins::DataObjects::Image >( "Output" );
+  typedef cpPlugins::DataObjects::Image _TImage;
+  this->_ConfigureInput< _TImage >( "Input1", true, false );
+  this->_ConfigureInput< _TImage >( "Input2", true, false );
+  this->_ConfigureOutput< _TImage >( "Output" );
 
   this->m_Parameters.ConfigureAsReal( "Constant" );
   this->m_Parameters.SetReal( "Constant", 1 );
@@ -27,26 +28,33 @@ cpPluginsImageArithmeticFilters::PowImageFilter::
 void cpPluginsImageArithmeticFilters::PowImageFilter::
 _GenerateData( )
 {
-  auto o = this->GetInputData( "Input0" );
-  cpPlugins_Demangle_ImageScalars_Dims( o, _GD0 );
-  else this->_Error( "Invalid input image." );
+  auto o = this->GetInputData( "Input1" );
+  cpPlugins_Demangle_Image_ScalarPixels_AllDims_1( o, _GD0 )
+    this->_Error( "Invalid input image (0)." );
 }
 
 // -------------------------------------------------------------------------
-template< class _TImage >
+template< class _TInput1 >
 void cpPluginsImageArithmeticFilters::PowImageFilter::
-_GD0( _TImage* image0 )
+_GD0( _TInput1* input1 )
 {
-  typedef itk::PowImageFilter< _TImage, _TImage > _TFilter;
+  auto input2 = this->GetInputData< _TInput1 >( "Input2" );
+  if( input2 == NULL )
+    this->_Error( "Incompatible second input image." );
+  this->_GD1( input2, input1 );
+}
+
+// -------------------------------------------------------------------------
+template< class _TInput2, class _TInput1 >
+void cpPluginsImageArithmeticFilters::PowImageFilter::
+_GD1( _TInput2* input2, _TInput1* input1 )
+{
+  typedef itk::PowImageFilter< _TInput1, _TInput2, _TInput1 > _TFilter;
 
   // Configure filter
   auto filter = this->_CreateITK< _TFilter >( );
-  filter->SetInput1( image0 );
-  auto image1 = this->GetInputData< _TImage >( "Input1" );
-  if( image1 == NULL )
-    filter->SetConstant( this->m_Parameters.GetReal( "Constant" ) );
-  else
-    filter->SetInput2( image1 );
+  filter->SetInput1( input1 );
+  filter->SetInput2( input2 );
   filter->Update( );
 
   // Connect output
@@ -54,3 +62,18 @@ _GD0( _TImage* image0 )
 }
 
 // eof - $RCSfile$
+
+/* TODO
+   filter->SetInput1( image0 );
+   auto image1 = this->GetInputData< _TImage >( "Input1" );
+   if( image1 == NULL )
+   filter->SetConstant( this->m_Parameters.GetReal( "Constant" ) );
+   else
+   filter->SetInput2( image1 );
+   filter->Update( );
+
+   // Connect output
+   this->GetOutput( "Output" )->SetITK( filter->GetOutput( ) );
+*/
+
+// eof - $RCSfile$