]> Creatis software - cpPlugins.git/blob - appli/examples/example_RenderQuadEdgeMesh.cxx
Examples with meshes (read and render, with and without plugins) added.
[cpPlugins.git] / appli / examples / example_RenderQuadEdgeMesh.cxx
1 #include <cstdlib>
2 #include <iostream>
3 #include <string>
4
5 #include <cpPlugins/Interface/Interface.h>
6 #include <cpPlugins/Interface/ProcessObject.h>
7 #include <cpPlugins/Interface/Mesh.h>
8
9 #include <vtkActor.h>
10 #include <vtkCallbackCommand.h>
11 #include <vtkProperty.h>
12 #include <vtkRenderer.h>
13 #include <vtkRenderWindow.h>
14 #include <vtkRenderWindowInteractor.h>
15 #include <vtkSmartPointer.h>
16
17 int main( int argc, char* argv[] )
18 {
19   if( argc < 5 )
20   {
21     std::cerr
22       << "Usage: " << argv[ 0 ]
23       << " plugins_file"
24       << " input_mesh"
25       << " dimensions pixel_type" << std::endl;
26     return( 1 );
27
28   } // fi
29   std::string plugins_file = argv[ 1 ];
30   std::string input_mesh_file = argv[ 2 ];
31   std::string dimensions = argv[ 3 ];
32   std::string pixel_type = argv[ 4 ];
33
34   // Create interface
35   typedef cpPlugins::Interface::Interface TInterface;
36   typedef TInterface::TClasses            TClasses;
37
38   TInterface plugins;
39   plugins.Load( plugins_file );
40
41   // Create objects
42   typedef cpPlugins::Interface::ProcessObject TProcessObject;
43   typedef TProcessObject::TParameters         TParameters;
44   cpPlugins::Interface::ProcessObject* reader;
45
46   reader =
47     dynamic_cast< TProcessObject* >(
48       plugins.CreateObject( "cpPlugins::Plugins::MeshReader" )
49       );
50   if( reader == NULL )
51   {
52     std::cerr << "No suitable reader found in plugins." << std::endl;
53     return( 1 );
54
55   } // fi
56
57   // Configure reader
58   TParameters reader_params = reader->GetDefaultParameters( );
59   reader_params[ "FileName" ].second = input_mesh_file;
60   reader_params[ "PixelType" ].second = pixel_type;
61   reader_params[ "MeshDimension" ].second = dimensions;
62   reader->SetParameters( reader_params );
63
64   // Execute reader
65   std::string msg = reader->Update( );
66
67   if( msg != "" )
68     std::cerr << "ERROR: " << msg << std::endl;
69
70   // Create actor
71   vtkSmartPointer< vtkActor > actor =
72     vtkSmartPointer< vtkActor >::New( );
73   actor->SetMapper(
74     dynamic_cast< cpPlugins::Interface::Mesh* >( reader->GetOutput( 0 ) )->
75     GetVTKMapper( )
76     );
77   actor->GetProperty( )->SetColor( 1, 1, 0 );
78   actor->GetProperty( )->SetOpacity( 0.5 );
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( 800, 800 );
89
90   // Set up the interaction
91   vtkSmartPointer< vtkRenderWindowInteractor > interactor =
92     vtkSmartPointer< vtkRenderWindowInteractor >::New( );
93   window->SetInteractor( interactor );
94
95   // Associate actors
96   renderer->AddActor( actor );
97
98   // Begin interaction
99   window->Render( );
100   interactor->Start( );
101
102   // Free memory
103   delete reader;
104
105   return( 0 );
106 }
107
108 // eof - $RCSfile$