-
Notifications
You must be signed in to change notification settings - Fork 53
/
Copy pathPointAreaMain.cpp
53 lines (44 loc) · 1.29 KB
/
PointAreaMain.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
#include "../PointAreaComputer.h"
#include "../MeshAnalyser.h"
#include <vtkPolyData.h>
#include <vtkPolyDataReader.h>
#include <vtkSmartPointer.h>
#include <vtkMNIObjectReader.h>
#include <vtkSTLReader.h>
#include <vtksys/SystemTools.hxx>
#include <iostream>
#include <fstream>
#include <stdio.h>
template<class TReader> vtkPolyData *ReadObject(const char*fileName)
{
vtkSmartPointer<TReader> reader =
vtkSmartPointer<TReader>::New();
reader->SetFileName(fileName);
reader->Update();
reader->GetOutput()->Register(reader);
return reader->GetOutput();
}
void print_help()
{
printf(
"Usage: PointAreaComputer InputVTKMesh\n"
);
}
int main(int argc, char** argv)
{
time_t start= time(NULL);
vtkPolyData *dataSet;
std::string extension = ".vtk";
//vtksys::SystemTools::GetFilenameLastExtension(argv[1]);
if (extension == ".vtk")
dataSet = ReadObject<vtkPolyDataReader> (argv[1]);
else if (extension == ".obj")
dataSet = ReadObject<vtkMNIObjectReader> (argv[1]);
else if (extension == ".stl")
dataSet = ReadObject<vtkSTLReader> (argv[1]);
PointAreaComputer* area = new PointAreaComputer(dataSet);
area->ComputeArea();
area->WriteIntoFile(argv[2]);
cout<<"Elapsed time (area): "<<time(NULL)-start<<" s"<<endl;
return 0;
}