DGtal 1.4.0
Loading...
Searching...
No Matches
SurfaceMeshReader.h
1
17#pragma once
18
31#if defined(SurfaceMeshReader_RECURSES)
32#error Recursive header files inclusion detected in SurfaceMeshReader.h
33#else // defined(SurfaceMeshReader_RECURSES)
35#define SurfaceMeshReader_RECURSES
36
37#if !defined SurfaceMeshReader_h
39#define SurfaceMeshReader_h
40
42// Inclusions
43#include <iostream>
44#include <sstream>
45#include <string>
46#include "DGtal/base/Common.h"
47#include "DGtal/helpers/StdDefs.h"
48#include "DGtal/shapes/SurfaceMesh.h"
49
50namespace DGtal
51{
52
54 // template class SurfaceMeshReader
62 template < typename TRealPoint, typename TRealVector >
64 {
65 typedef TRealPoint RealPoint;
66 typedef TRealVector RealVector;
70
72 typedef typename SurfaceMesh::Size Size;
73 typedef typename SurfaceMesh::Index Index;
75 typedef typename SurfaceMesh::Faces Faces;
76
80 static bool verifyIndicesUniqueness( const std::vector< Index > &indices );
81
87 static
88 std::vector< std::string > split( const std::string& str, char delim = ' ');
89
98 static
99 bool readOBJ( std::istream & input, SurfaceMesh & smesh );
100 };
101
102} // namespace DGtal
103
105// Includes inline functions.
106#include "SurfaceMeshReader.ih"
107// //
109
110#endif // !defined SurfaceMeshReader_h
111
112#undef SurfaceMeshReader_RECURSES
113#endif // else defined(SurfaceMeshReader_RECURSES)
static const Dimension dimension
DGtal is the top-level namespace which contains all DGtal functions and types.
DGtal::uint32_t Dimension
Definition Common.h:136
Aim: An helper class for reading mesh files (Wavefront OBJ at this point) and creating a SurfaceMesh.
static const Dimension dimension
static bool verifyIndicesUniqueness(const std::vector< Index > &indices)
static bool readOBJ(std::istream &input, SurfaceMesh &smesh)
SurfaceMeshReader< RealPoint, RealVector > Self
BOOST_STATIC_ASSERT((dimension==3))
SurfaceMesh::Vertices Vertices
DGtal::SurfaceMesh< RealPoint, RealVector > SurfaceMesh
static std::vector< std::string > split(const std::string &str, char delim=' ')
Aim: Represents an embedded mesh as faces and a list of vertices. Vertices may be shared among faces ...
Definition SurfaceMesh.h:92
std::vector< Vertex > Vertices
The type that defines a list/range of vertices (e.g. to define faces)
std::size_t Index
The type used for numbering vertices and faces.
std::size_t Size
The type for counting elements.
std::vector< Face > Faces