OpenMesh
generate_cube.hh
1#ifndef GENERATE_CUBE_HH
2#define GENERATE_CUBE_HH
3
4template <typename MeshType>
5size_t generate_cube( MeshType& mesh )
6{
7 typedef typename MeshType::VertexHandle VertexHandle;
8 typedef typename MeshType::Point Point;
9
10 typename MeshType::VertexHandle vhandle[8];
11
12 vhandle[0] = mesh.add_vertex(Point(-1, -1, 1));
13 vhandle[1] = mesh.add_vertex(Point( 1, -1, 1));
14 vhandle[2] = mesh.add_vertex(Point( 1, 1, 1));
15 vhandle[3] = mesh.add_vertex(Point(-1, 1, 1));
16 vhandle[4] = mesh.add_vertex(Point(-1, -1, -1));
17 vhandle[5] = mesh.add_vertex(Point( 1, -1, -1));
18 vhandle[6] = mesh.add_vertex(Point( 1, 1, -1));
19 vhandle[7] = mesh.add_vertex(Point(-1, 1, -1));
20
21 // generate (quadrilateral) faces
22
23 std::vector< VertexHandle > face_vhandles;
24
25 face_vhandles.clear();
26 face_vhandles.push_back(vhandle[0]);
27 face_vhandles.push_back(vhandle[1]);
28 face_vhandles.push_back(vhandle[2]);
29 face_vhandles.push_back(vhandle[3]);
30 mesh.add_face(face_vhandles);
31
32 face_vhandles.clear();
33 face_vhandles.push_back(vhandle[7]);
34 face_vhandles.push_back(vhandle[6]);
35 face_vhandles.push_back(vhandle[5]);
36 face_vhandles.push_back(vhandle[4]);
37 mesh.add_face(face_vhandles);
38
39 face_vhandles.clear();
40 face_vhandles.push_back(vhandle[1]);
41 face_vhandles.push_back(vhandle[0]);
42 face_vhandles.push_back(vhandle[4]);
43 face_vhandles.push_back(vhandle[5]);
44 mesh.add_face(face_vhandles);
45
46 face_vhandles.clear();
47 face_vhandles.push_back(vhandle[2]);
48 face_vhandles.push_back(vhandle[1]);
49 face_vhandles.push_back(vhandle[5]);
50 face_vhandles.push_back(vhandle[6]);
51 mesh.add_face(face_vhandles);
52
53 face_vhandles.clear();
54 face_vhandles.push_back(vhandle[3]);
55 face_vhandles.push_back(vhandle[2]);
56 face_vhandles.push_back(vhandle[6]);
57 face_vhandles.push_back(vhandle[7]);
58 mesh.add_face(face_vhandles);
59
60 face_vhandles.clear();
61 face_vhandles.push_back(vhandle[0]);
62 face_vhandles.push_back(vhandle[3]);
63 face_vhandles.push_back(vhandle[7]);
64 face_vhandles.push_back(vhandle[4]);
65 mesh.add_face(face_vhandles);
66
67 return mesh.n_vertices();
68};
69
70#endif

Project OpenMesh, ©  Visual Computing Institute, RWTH Aachen. Documentation generated using doxygen .