5 #include <cpPlugins/Interface/Interface.h>
6 #include <cpPlugins/Interface/ProcessObject.h>
8 int main( int argc, char* argv[] )
13 << "Usage: " << argv[ 0 ]
15 << " input_image output_image" << std::endl;
21 typedef cpPlugins::Interface::Interface TInterface;
22 typedef TInterface::TClasses TClasses;
24 if( !plugins.Load( argv[ 1 ] ) )
26 std::cerr << "Failed to load plugins." << std::endl;
32 typedef cpPlugins::Interface::ProcessObject TProcessObject;
33 typedef cpPlugins::Interface::Parameters TParameters;
34 cpPlugins::Interface::ProcessObject::Pointer reader, writer, otsu;
35 reader = plugins.CreateProcessObject( "cpPlugins::ImageReader" );
36 writer = plugins.CreateProcessObject( "cpPlugins::ImageWriter" );
37 otsu = plugins.CreateProcessObject( "cpPlugins::OtsuThresholdImageFilter" );
38 if( reader.IsNull( ) || writer.IsNull( ) || otsu.IsNull( ) )
40 std::cerr << "No suitable objects found in plugins." << std::endl;
46 TParameters reader_params = reader->GetDefaultParameters( );
47 for( int i = 2; i < argc - 1; ++i )
48 reader_params.AddValueToStringList( "FileNames", argv[ i ] );
49 reader->SetParameters( reader_params );
52 TParameters otsu_params = otsu->GetDefaultParameters( );
53 otsu_params.SetValueAsUint( "NumberOfHistogramBins", 100 );
54 otsu_params.SetValueAsReal( "InsideValue", 255 );
55 otsu_params.SetValueAsReal( "OutsideValue", 0 );
56 otsu->SetParameters( otsu_params );
59 TParameters writer_params = writer->GetDefaultParameters( );
60 writer_params.SetValueAsString( "FileName", argv[ argc - 1 ] );
61 writer->SetParameters( writer_params );
64 otsu->SetInput( 0, reader->GetOutput( 0 ) );
65 writer->SetInput( 0, otsu->GetOutput( 0 ) );
68 std::string err = writer->Update( );
71 std::cerr << "ERROR: " << err << std::endl;