-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvxVrmlOut.cpp
69 lines (58 loc) · 1.65 KB
/
vxVrmlOut.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
/**
*
* file vxVrmlOut.cpp
*
* This source file is a part of VoxelBrain software.
*
* (c) Nanyang Technological University
*
* Author: Konstantin Levinski
*
*/
#include "vxVrmlOut.h"
#include <sstream>
std::string VrmlTemplate(std::string vertices, std::string normals, std::string colors, std::string indices){
std::string result;
result+= "#VRML V2.0 utf8\n\n"
"Shape {"
"geometry IndexedFaceSet {"
"coord Coordinate {"
"point [" + vertices + \
"] }\n";
if(normals.size() > 0)
result += "normal Normal {"
"vector [" + normals+ "]}";
if(colors.size() > 0)
result+= "color Color {"
"color [" + colors + "]}";
result += "coordIndex [" + indices + "]}"
"appearance Appearance {"
"material Material {"
"diffuseColor 1 1 1"
"}}}";
return result;
};
std::string VrmlFormat(vector<V3f> vertices, bool invert){
int cnt = 1;
std::stringstream result;
for(vector<V3f>::iterator i = vertices.begin(); i != vertices.end();){
cnt++;
if(!invert)
result << (*i).x << " " << (*i).y << " " << (*i).z ;
else
result << -(*i).x << " " << -(*i).y << " " << -(*i).z ;
if(++i != vertices.end()) result << "," << (cnt%5?" ":"\n");
};
return result.str();
};
std::string VrmlFormat(vector<V3i> indices){
int cnt = 1; //for formatting.
std::stringstream result;
for(vector<V3i>::iterator i = indices.begin(); i != indices.end();){
cnt++;
result << (*i).x << " " << (*i).y << " " << (*i).z;
if(++i != indices.end()) result << " -1" << (cnt%5?" ":"\n"); //Vrml convention for faces.
};
return result.str();
};
// End of vxVrmlOut.cpp