]> Creatis software - cpPlugins.git/blob - lib/cpPlugins/Plugins/IO/ImageWriter.cxx
ba9417324d4f394d4e8c552a0ef6bef94bd7f105
[cpPlugins.git] / lib / cpPlugins / Plugins / IO / ImageWriter.cxx
1 #include "ImageWriter.h"
2 #include <cpPlugins/Interface/Image.h>
3
4 #include <itkImageFileWriter.h>
5
6 // -------------------------------------------------------------------------
7 cpPlugins::IO::ImageWriter::
8 ImageWriter( )
9   : Superclass( )
10 {
11   this->m_ClassName = "cpPlugins::IO::ImageWriter";
12   this->m_ClassCategory = "ImageWriter";
13   this->SetNumberOfInputs( 1 );
14
15   using namespace cpPlugins::Interface;
16   this->m_DefaultParameters.Configure( Parameters::String, "FileName" );
17   this->m_Parameters = this->m_DefaultParameters;
18 }
19
20 // -------------------------------------------------------------------------
21 cpPlugins::IO::ImageWriter::
22 ~ImageWriter( )
23 {
24 }
25
26 // -------------------------------------------------------------------------
27 std::string cpPlugins::IO::ImageWriter::
28 _GenerateData( )
29 {
30   cpPlugins::Interface::Image* image =
31     this->GetInput< cpPlugins::Interface::Image >( 0 );
32   if( image == NULL )
33     return( "ImageWriter: No input image." );
34
35   itk::DataObject* itk_image = NULL;
36   std::string r = "";
37   /*
38   cpPlugins_Image_Demangle_AllTypes( 2, image, itk_image, r, _RealGD );
39   else cpPlugins_Image_Demangle_AllTypes( 3, image, itk_image, r, _RealGD );
40   else cpPlugins_Image_Demangle_AllTypes( 4, image, itk_image, r, _RealGD );
41   else cpPlugins_VectorImage_Demangle_AllTypes( 2, image, itk_image, r, _RealGD );
42   else cpPlugins_VectorImage_Demangle_AllTypes( 3, image, itk_image, r, _RealGD );
43   else cpPlugins_VectorImage_Demangle_AllTypes( 4, image, itk_image, r, _RealGD );
44   else */r = "ImageWriter: Input image type not supported.";
45
46   return( r );
47 }
48
49 // -------------------------------------------------------------------------
50 template< class I >
51 std::string cpPlugins::IO::ImageWriter::
52 _RealGD( itk::DataObject* image )
53 {
54   // Get filename
55   std::string fname = this->m_Parameters.GetValueAsString( "FileName" );
56
57   typedef itk::ImageFileWriter< I > _W;
58   _W* writer = this->_CreateITK< _W >( );
59   writer->SetFileName( fname );
60   writer->SetInput( dynamic_cast< I* >( image ) );
61   try
62   {
63     writer->Update( );
64   }
65   catch( itk::ExceptionObject& err )
66   {
67     return( "ImageWriter: " + std::string( err.GetDescription( ) ) );
68
69   } // yrt
70   return( "" );
71 }
72
73 // eof - $RCSfile$