]> Creatis software - cpMesh.git/blob - appli/examples/example_RenderQuadEdgeMesh.cxx
5276fa582e10d683e2f46309f9f857806516b19f
[cpMesh.git] / appli / examples / example_RenderQuadEdgeMesh.cxx
1 #include <cmath>
2 #include <cstdlib>
3 #include <iostream>
4 #include <string>
5
6 #include <cpm/DataStructures/QuadEdgeMesh.h>
7 #include <cpm/IO/MeshReader.h>
8 #include <itkRegularSphereMeshSource.h>
9 #include <vnl/vnl_math.h>
10
11 #include <vtkActor.h>
12 #include <vtkCallbackCommand.h>
13 #include <vtkProperty.h>
14 #include <vtkRenderer.h>
15 #include <vtkRenderWindow.h>
16 #include <vtkRenderWindowInteractor.h>
17 #include <vtkSmartPointer.h>
18 #include <cpm/VTK/MeshMapper.h>
19
20 // -------------------------------------------------------------------------
21 const unsigned int Dimension = 3;
22 typedef float TScalar;
23 typedef cpm::DataStructures::QuadEdgeMesh< TScalar, Dimension > TMesh;
24 typedef cpm::VTK::MeshMapper< TMesh > TMeshMapper;
25
26 // -------------------------------------------------------------------------
27 static void CallbackFunction(
28   vtkObject* caller, long unsigned int eventId,
29   void* clientData, void* callData
30   );
31
32 // -------------------------------------------------------------------------
33 int main( int argc, char* argv[] )
34 {
35   TMesh::Pointer mesh;
36   if( argc > 1 )
37   {
38     typedef cpm::IO::MeshReader< TMesh > TReader;
39     TReader::Pointer reader = TReader::New( );
40     reader->SetFileName( argv[ 1 ] );
41     reader->Update( );
42     mesh = reader->GetOutput( );
43   }
44   else
45   {
46     typedef itk::RegularSphereMeshSource< TMesh > TSphereSource;
47     TSphereSource::Pointer source = TSphereSource::New( );
48     source->SetResolution( 0 );
49     source->Update( );
50     mesh = source->GetOutput( );
51
52   } // fi
53
54   // Map mesh
55   vtkSmartPointer< TMeshMapper > mapper =
56     vtkSmartPointer< TMeshMapper >::New( );
57   mapper->SetInputData( mesh );
58
59   // Create actor
60   vtkSmartPointer< vtkActor > actor =
61     vtkSmartPointer< vtkActor >::New( );
62   actor->SetMapper( mapper );
63   actor->GetProperty( )->SetColor( 1, 1, 0 );
64   actor->GetProperty( )->SetOpacity( 1 );
65
66   // Configure visualization objects
67   vtkSmartPointer< vtkRenderer > renderer =
68     vtkSmartPointer< vtkRenderer >::New( );
69   renderer->SetBackground( 0.1, 0.3, 0.5 );
70
71   vtkSmartPointer< vtkRenderWindow > window =
72     vtkSmartPointer< vtkRenderWindow >::New( );
73   window->AddRenderer( renderer );
74   window->SetSize( 800, 800 );
75
76   // Set up the interaction
77   vtkSmartPointer< vtkRenderWindowInteractor > interactor =
78     vtkSmartPointer< vtkRenderWindowInteractor >::New( );
79   window->SetInteractor( interactor );
80
81   // Associate actors
82   renderer->AddActor( actor );
83
84   // Some callbacks
85   vtkSmartPointer< vtkCallbackCommand > callback =
86     vtkSmartPointer< vtkCallbackCommand >::New( );
87   callback->SetCallback( CallbackFunction );
88   renderer->AddObserver( vtkCommand::EndEvent, callback );
89
90   // Begin interaction
91   window->Render( );
92   interactor->Start( );
93
94   return( 0 );
95 }
96
97 // -------------------------------------------------------------------------
98 void CallbackFunction(
99   vtkObject* caller, long unsigned int eventId,
100   void* clientData, void* callData
101   )
102 {
103   vtkRenderer* renderer = static_cast< vtkRenderer* >( caller );
104   double timeInSeconds = renderer->GetLastRenderTimeInSeconds( );
105   double fps = 1.0 / timeInSeconds;
106   std::cout << "FPS: " << fps << std::endl;
107 }
108
109 // eof - $RCSfile$