]> Creatis software - cpPlugins.git/blob - appli/examples/example_View2DImage.cxx
...
[cpPlugins.git] / appli / examples / example_View2DImage.cxx
1 #include <cstdlib>
2 #include <iostream>
3 #include <string>
4 #include <vector>
5
6 #include <vtkRenderer.h>
7 #include <vtkRenderWindow.h>
8 #include <vtkRenderWindowInteractor.h>
9
10 #include <cpPlugins/Interface/Plugins.h>
11 #include <cpPlugins/Interface/Image.h>
12
13 #include <cpExtensions/Visualization/ImageSliceActors.h>
14
15 // -------------------------------------------------------------------------
16 typedef cpPlugins::Interface::Plugins                 TPlugins;
17 typedef cpPlugins::Interface::Image                   TImage;
18 typedef cpExtensions::Visualization::ImageSliceActors TSliceActors;
19
20 // -------------------------------------------------------------------------
21 int main( int argc, char* argv[] )
22 {
23   if( argc < 3 )
24   {
25     std::cerr
26       << "Usage: " << argv[ 0 ]
27       << " plugins_file input_image"
28       << std::endl;
29     return( 1 );
30
31   } // fi
32
33   // Load plugins
34   cpPlugins::Interface::Plugins plugins;
35   if( !plugins.LoadPluginsPath( argv[ 1 ] ) )
36   {
37     std::cerr << "Failed to load plugins." << std::endl;
38     return( 1 );
39
40   } // fi
41
42   // Associate filenames
43   std::vector< std::string > fnames;
44   for( int i = 2; i < argc; ++i )
45     fnames.push_back( argv[ i ] );
46   
47   // Read image
48   std::string name = "";
49   try
50   {
51     name = plugins.ReadImage( fnames, "" );
52   }
53   catch( std::exception& err )
54   {
55     std::cerr << err.what( ) << std::endl;
56     return( 1 );
57
58   } // yrt
59   TImage* image = plugins.GetData< TImage >( name );
60
61   // Configure visualization objects
62   vtkSmartPointer< vtkRenderer > renderer =
63     vtkSmartPointer< vtkRenderer >::New( );
64   renderer->SetBackground( 0.1, 0.3, 0.5 );
65
66   vtkSmartPointer< vtkRenderWindow > window =
67     vtkSmartPointer< vtkRenderWindow >::New( );
68   window->AddRenderer( renderer );
69   window->SetSize( 600, 600 );
70
71   // Set up the interaction
72   vtkSmartPointer< vtkRenderWindowInteractor > interactor =
73     vtkSmartPointer< vtkRenderWindowInteractor >::New( );
74   window->SetInteractor( interactor );
75
76   // Create slice actors
77   vtkSmartPointer< TSliceActors > image_actors =
78     vtkSmartPointer< TSliceActors >::New( );
79   image_actors->SetInputImage( image->GetVTK< vtkImageData >( ) );
80   image_actors->SetAxis( 2 );
81   image_actors->PushActorsInto( window );
82
83   // Activate seed widget
84   if( argc == 4 )
85   {
86     TSliceActors::TStyle* style =
87       dynamic_cast< TSliceActors::TStyle* >( image_actors->GetStyle( ) );
88     if( style != NULL )
89     {
90       if( std::string( argv[ 3 ] ) == std::string( "seed" ) )
91         style->SeedWidgetOn( );
92
93     } // fi
94
95   } // fi
96
97   // Begin interaction
98   renderer->ResetCamera( );
99   window->Render( );
100   interactor->Start( );
101
102   return( 0 );
103 }
104
105 // eof - $RCSfile$