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