5 #include <cpPlugins/Interface/Interface.h>
6 #include <cpPlugins/Interface/ProcessObject.h>
7 #include <cpPlugins/Interface/Mesh.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>
17 int main( int argc, char* argv[] )
22 << "Usage: " << argv[ 0 ]
25 << " dimensions pixel_type" << std::endl;
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 ];
35 typedef cpPlugins::Interface::Interface TInterface;
36 typedef TInterface::TClasses TClasses;
39 plugins.Load( plugins_file );
42 typedef cpPlugins::Interface::ProcessObject TProcessObject;
43 typedef TProcessObject::TParameters TParameters;
44 cpPlugins::Interface::ProcessObject* reader;
47 dynamic_cast< TProcessObject* >(
48 plugins.CreateObject( "cpPlugins::Plugins::MeshReader" )
52 std::cerr << "No suitable reader found in plugins." << std::endl;
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 );
65 std::string msg = reader->Update( );
68 std::cerr << "ERROR: " << msg << std::endl;
71 vtkSmartPointer< vtkActor > actor =
72 vtkSmartPointer< vtkActor >::New( );
74 dynamic_cast< cpPlugins::Interface::Mesh* >( reader->GetOutput( 0 ) )->
77 actor->GetProperty( )->SetColor( 1, 1, 0 );
78 actor->GetProperty( )->SetOpacity( 0.5 );
80 // Configure visualization objects
81 vtkSmartPointer< vtkRenderer > renderer =
82 vtkSmartPointer< vtkRenderer >::New( );
83 renderer->SetBackground( 0.1, 0.3, 0.5 );
85 vtkSmartPointer< vtkRenderWindow > window =
86 vtkSmartPointer< vtkRenderWindow >::New( );
87 window->AddRenderer( renderer );
88 window->SetSize( 800, 800 );
90 // Set up the interaction
91 vtkSmartPointer< vtkRenderWindowInteractor > interactor =
92 vtkSmartPointer< vtkRenderWindowInteractor >::New( );
93 window->SetInteractor( interactor );
96 renderer->AddActor( actor );
100 interactor->Start( );