-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathmain.cpp
85 lines (65 loc) · 2.5 KB
/
main.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
//VTK includes
#include <vtkSmartPointer.h>
#include <vtkRenderer.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkRenderWindow.h>
#include <vtkPolyDataMapper.h>
//Reader includes
#include "vtkGeoJSONReader.h"
#include "vtkLASReader.h"
int TestGeoJSON(int argc, char **argv);
int TestLASLidar(int argc, char **argv);
int main(int argc, char **argv)
{
// return TestLASLidar(argc, argv);
return TestGeoJSON(argc, argv);
}
int TestGeoJSON(int argc, char **argv)
{
//Reader
vtkGeoJSONReader *reader = vtkGeoJSONReader::New();
//Select source file
reader->SetFileName("JSONSample/india_outline.json");
//Read the output
reader->Update();
vtkPolyData *outputData = reader->GetOutput();
//Visualise in a render window
vtkSmartPointer<vtkPolyDataMapper> mapper = vtkSmartPointer<vtkPolyDataMapper>::New();
mapper->SetInputData(outputData);
vtkSmartPointer<vtkActor> actor = vtkSmartPointer<vtkActor>::New();
actor->SetMapper(mapper);
vtkSmartPointer<vtkRenderer> renderer = vtkSmartPointer<vtkRenderer>::New();
vtkSmartPointer<vtkRenderWindow> renderWindow = vtkSmartPointer<vtkRenderWindow>::New();
renderWindow->AddRenderer(renderer);
vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor = vtkSmartPointer<vtkRenderWindowInteractor>::New();
renderWindowInteractor->SetRenderWindow(renderWindow);
renderer->AddActor(actor);
renderWindow->Render();
renderWindowInteractor->Start();
return EXIT_SUCCESS;
}
int TestLASLidar(int argc, char **argv)
{
//Reader
vtkLASReader *reader = vtkLASReader::New();
//Select source file
reader->SetFileName("LASSample/test_1.las");
reader->SetVisualisationType(vtkLASReader::Classification);
//Read the output
reader->Update();
vtkPolyData *outputData = reader->GetOutput();
//Visualise in a render window
vtkSmartPointer<vtkPolyDataMapper> mapper = vtkSmartPointer<vtkPolyDataMapper>::New();
mapper->SetInputData(outputData);
vtkSmartPointer<vtkActor> actor = vtkSmartPointer<vtkActor>::New();
actor->SetMapper(mapper);
vtkSmartPointer<vtkRenderer> renderer = vtkSmartPointer<vtkRenderer>::New();
vtkSmartPointer<vtkRenderWindow> renderWindow = vtkSmartPointer<vtkRenderWindow>::New();
renderWindow->AddRenderer(renderer);
vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor = vtkSmartPointer<vtkRenderWindowInteractor>::New();
renderWindowInteractor->SetRenderWindow(renderWindow);
renderer->AddActor(actor);
renderWindow->Render();
renderWindowInteractor->Start();
return EXIT_SUCCESS;
}