]> Creatis software - cpPlugins.git/blob - appli/examples/example_View2DImage.cxx
Binary image visualization improved.
[cpPlugins.git] / appli / examples / example_View2DImage.cxx
1 #include <cstdlib>
2 #include <iostream>
3 #include <string>
4
5 #include <vtkRenderer.h>
6 #include <vtkRenderWindow.h>
7 #include <vtkRenderWindowInteractor.h>
8
9 #include <cpPlugins/Interface/Interface.h>
10 #include <cpPlugins/Interface/ProcessObject.h>
11 #include <cpPlugins/Interface/Image.h>
12
13 #include <cpExtensions/Visualization/ImageSliceActors.h>
14
15 // -------------------------------------------------------------------------
16 typedef cpPlugins::Interface::Interface     TInterface;
17 typedef cpPlugins::Interface::ProcessObject TProcessObject;
18 typedef cpPlugins::Interface::DataObject    TDataObject;
19 typedef cpPlugins::Interface::Image         TImage;
20 typedef cpPlugins::Interface::Parameters    TParameters;
21 typedef TInterface::TClasses                TClasses;
22
23 typedef cpExtensions::Visualization::ImageSliceActors TSliceActors;
24
25 // -------------------------------------------------------------------------
26 int main( int argc, char* argv[] )
27 {
28   if( argc < 3 )
29   {
30     std::cerr
31       << "Usage: " << argv[ 0 ]
32       << " plugins_file input_image [widget]"
33       << std::endl;
34     return( 1 );
35
36   } // fi
37
38   // Create interface
39   TInterface plugins;
40   if( !plugins.Load( argv[ 1 ] ) )
41   {
42     std::cerr << "Failed to load plugins." << std::endl;
43     return( 1 );
44
45   } // fi
46
47   // Create objects
48   TProcessObject::Pointer reader;
49   reader = plugins.CreateProcessObject( "cpPlugins::IO::ImageReader" );
50   if( reader.IsNull( ) )
51   {
52     std::cerr
53       << "No suitable reader found in plugins." << std::endl
54       << "Reader: " << reader.GetPointer( ) << std::endl
55       << std::endl;
56     return( 1 );
57
58   } // fi
59
60   // Configure reader
61   TParameters* reader_params = reader->GetParameters( );
62   if( argc > 4 )
63   {
64     for( int i = 2; i < argc; ++i )
65       reader_params->AddToStringList( "FileNames", argv[ i ] );
66   }
67   else
68     reader_params->AddToStringList( "FileNames", argv[ 2 ] );
69
70   // Execute pipeline
71   std::string err = reader->Update( );
72   if( err != "" )
73   {
74     std::cerr << "ERROR: " << err << std::endl;
75     return( 1 );
76
77   } // fi
78   TImage* image = reader->GetOutput< TImage >( "Output" );
79
80   // Configure visualization objects
81   vtkSmartPointer< vtkRenderer > renderer =
82     vtkSmartPointer< vtkRenderer >::New( );
83   renderer->SetBackground( 0.1, 0.3, 0.5 );
84
85   vtkSmartPointer< vtkRenderWindow > window =
86     vtkSmartPointer< vtkRenderWindow >::New( );
87   window->AddRenderer( renderer );
88   window->SetSize( 600, 600 );
89
90   // Set up the interaction
91   vtkSmartPointer< vtkRenderWindowInteractor > interactor =
92     vtkSmartPointer< vtkRenderWindowInteractor >::New( );
93   window->SetInteractor( interactor );
94
95   // Create slice actors
96   vtkSmartPointer< TSliceActors > image_actors =
97     vtkSmartPointer< TSliceActors >::New( );
98   image_actors->AddInputData( image->GetVTK< vtkImageData >( ) );
99   image_actors->SetAxis( 2 );
100   image_actors->PushActorsInto( window );
101
102   // Activate seed widget
103   if( argc == 4 )
104   {
105     TSliceActors::TStyle* style =
106       dynamic_cast< TSliceActors::TStyle* >( image_actors->GetStyle( ) );
107     if( style != NULL )
108     {
109       if( std::string( argv[ 3 ] ) == std::string( "seed" ) )
110         style->SeedWidgetOn( );
111
112     } // fi
113
114   } // fi
115
116   // Begin interaction
117   image_actors->ResetCamera( );
118   window->Render( );
119   interactor->Start( );
120
121   return( 0 );
122 }
123
124 // eof - $RCSfile$