]> Creatis software - cpPlugins.git/blob - appli/examples/example_ReadImageSeriesWriteImage.cxx
c0bc7ad79afe3b5675bb66900d460722bca1d0f1
[cpPlugins.git] / appli / examples / example_ReadImageSeriesWriteImage.cxx
1 #include <cstdlib>
2 #include <iostream>
3 #include <string>
4 #include <vector>
5
6 #include <cpPlugins/Interface/Interface.h>
7 #include <cpPlugins/Interface/ProcessObject.h>
8
9 int main( int argc, char* argv[] )
10 {
11   if( argc < 7 )
12   {
13     std::cerr
14       << "Usage: " << argv[ 0 ]
15       << " plugins_file"
16       << " output_image"
17       << " dimensions pixel_type is_color input_image_files" << std::endl;
18     return( 1 );
19
20   } // fi
21   std::string plugins_file = argv[ 1 ];
22   std::string output_image_file = argv[ 2 ];
23   unsigned int dimensions = std::atoi( argv[ 3 ] );
24   std::string pixel_type = argv[ 4 ];
25   bool is_color = ( std::atoi( argv[ 5 ] ) == 1 );
26
27   std::vector< std::string > input_image_files;
28   for( int i = 6; i < argc; ++i )
29     input_image_files.push_back( argv[ i ] );
30
31   // Create interface
32   typedef cpPlugins::Interface::Interface TInterface;
33   typedef TInterface::TClasses            TClasses;
34
35   TInterface plugins;
36   plugins.Load( plugins_file );
37
38   // Create objects
39   typedef cpPlugins::Interface::ProcessObject TProcessObject;
40   typedef cpPlugins::Interface::Parameters    TParameters;
41   cpPlugins::Interface::ProcessObject::Pointer reader;
42   cpPlugins::Interface::ProcessObject::Pointer writer;
43
44   reader =
45     plugins.CreateProcessObject( "cpPlugins::Plugins::ImageSeriesReader" );
46   if( reader.IsNull( ) )
47   {
48     std::cerr << "No suitable reader found in plugins." << std::endl;
49     return( 1 );
50
51   } // fi
52   writer = plugins.CreateProcessObject( "cpPlugins::Plugins::ImageWriter" );
53   if( writer.IsNull( ) )
54   {
55     std::cerr << "No suitable writer found in plugins." << std::endl;
56     return( 1 );
57
58   } // fi
59
60   // Configure reader
61   TParameters reader_params = reader->GetDefaultParameters( );
62   reader_params.SetValueAsStringList(
63     "FileNames",
64     input_image_files.begin( ),
65     input_image_files.end( )
66     );
67   reader_params.SetValueAsString( "PixelType", pixel_type );
68   reader_params.SetValueAsUint( "ImageDimension", dimensions );
69   reader_params.SetValueAsUint( "IsColorImage", ( is_color? 1: 0 ) );
70   reader->SetParameters( reader_params );
71
72   // Configure reader
73   TParameters writer_params = writer->GetDefaultParameters( );
74   writer_params.SetValueAsString( "FileName", output_image_file );
75   writer->SetParameters( writer_params );
76
77   // Connect pipeline
78   writer->SetInput( 0, reader->GetOutput( 0 ) );
79
80   std::string msg = writer->Update( );
81
82   if( msg != "" )
83     std::cerr << "ERROR: " << msg << std::endl;
84
85   return( 0 );
86 }
87
88 // eof - $RCSfile$