]> Creatis software - cpPlugins.git/blobdiff - plugins/ImageBooleanFilters/XorImageFilter.cxx
Architecture updated.
[cpPlugins.git] / plugins / ImageBooleanFilters / XorImageFilter.cxx
diff --git a/plugins/ImageBooleanFilters/XorImageFilter.cxx b/plugins/ImageBooleanFilters/XorImageFilter.cxx
new file mode 100644 (file)
index 0000000..fdb0a5d
--- /dev/null
@@ -0,0 +1,53 @@
+#include <plugins/ImageBooleanFilters/XorImageFilter.h>
+#include <cpPlugins/DataObjects/Image.h>
+
+#include <itkXorImageFilter.h>
+#include <itkBinaryFunctorImageFilter.hxx>
+
+// -------------------------------------------------------------------------
+cpPluginsImageBooleanFilters::XorImageFilter::
+XorImageFilter( )
+  : Superclass( )
+{
+  this->_ConfigureInput< cpPlugins::DataObjects::Image >( "Input0", true, false );
+  this->_ConfigureInput< cpPlugins::DataObjects::Image >( "Input1", true, false );
+  this->_ConfigureOutput< cpPlugins::DataObjects::Image >( "Output" );
+}
+
+// -------------------------------------------------------------------------
+cpPluginsImageBooleanFilters::XorImageFilter::
+~XorImageFilter( )
+{
+}
+
+// -------------------------------------------------------------------------
+void cpPluginsImageBooleanFilters::XorImageFilter::
+_GenerateData( )
+{
+  auto o = this->GetInputData( "Input0" );
+  cpPlugins_Demangle_ImageIntegers_Dims( o, _GD0 );
+  else this->_Error( "Invalid input image." );
+}
+
+// -------------------------------------------------------------------------
+template< class _TImage >
+void cpPluginsImageBooleanFilters::XorImageFilter::
+_GD0( _TImage* image0 )
+{
+  typedef itk::XorImageFilter< _TImage, _TImage > _TFilter;
+
+  auto image1 = this->GetInputData< _TImage >( "Input1" );
+  if( image1 == NULL )
+    this->_Error( "Incompatible second input image." );
+
+  // Configure filter
+  auto filter = this->_CreateITK< _TFilter >( );
+  filter->SetInput( 0, image0 );
+  filter->SetInput( 1, image1 );
+  filter->Update( );
+
+  // Connect output
+  this->GetOutput( "Output" )->SetITK( filter->GetOutput( ) );
+}
+
+// eof - $RCSfile$