coal  3.0.1
Coal, The Collision Detection Library. Previously known as HPP-FCL, fork of FCL -- The Flexible Collision Library
assimp.h
Go to the documentation of this file.
1 /*
2  * Software License Agreement (BSD License)
3  *
4  * Copyright (c) 2011-2014, Willow Garage, Inc.
5  * Copyright (c) 2014-2015, Open Source Robotics Foundation
6  * Copyright (c) 2016-2019, CNRS - LAAS
7  * Copyright (c) 2019, INRIA
8  * All rights reserved.
9  *
10  * Redistribution and use in source and binary forms, with or without
11  * modification, are permitted provided that the following conditions
12  * are met:
13  *
14  * * Redistributions of source code must retain the above copyright
15  * notice, this list of conditions and the following disclaimer.
16  * * Redistributions in binary form must reproduce the above
17  * copyright notice, this list of conditions and the following
18  * disclaimer in the documentation and/or other materials provided
19  * with the distribution.
20  * * Neither the name of Open Source Robotics Foundation nor the names of its
21  * contributors may be used to endorse or promote products derived
22  * from this software without specific prior written permission.
23  *
24  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
25  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
26  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
27  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
28  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
29  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
30  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
31  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
32  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
33  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
34  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35  * POSSIBILITY OF SUCH DAMAGE.
36  */
37 
38 #ifndef COAL_MESH_LOADER_ASSIMP_H
39 #define COAL_MESH_LOADER_ASSIMP_H
40 
41 #include "coal/fwd.hh"
42 #include "coal/config.hh"
43 #include "coal/BV/OBBRSS.h"
44 #include "coal/BVH/BVH_model.h"
45 
46 struct aiScene;
47 namespace Assimp {
48 class Importer;
49 }
50 
51 namespace coal {
52 
53 namespace internal {
54 
56  std::vector<coal::Vec3s> vertices_;
57  std::vector<coal::Triangle> triangles_;
58 };
59 
61  Loader();
63 
64  void load(const std::string& resource_path);
65 
66  Assimp::Importer* importer;
67  aiScene const* scene;
68 };
69 
78 COAL_DLLAPI void buildMesh(const coal::Vec3s& scale, const aiScene* scene,
79  unsigned vertices_offset, TriangleAndVertices& tv);
80 
88 template <class BoundingVolume>
89 inline void meshFromAssimpScene(
90  const coal::Vec3s& scale, const aiScene* scene,
91  const shared_ptr<BVHModel<BoundingVolume> >& mesh) {
93 
94  int res = mesh->beginModel();
95 
96  if (res != coal::BVH_OK) {
97  COAL_THROW_PRETTY("fcl BVHReturnCode = " << res, std::runtime_error);
98  }
99 
100  buildMesh(scale, scene, (unsigned)mesh->num_vertices, tv);
101  mesh->addSubModel(tv.vertices_, tv.triangles_);
102 
103  mesh->endModel();
104 }
105 
106 } // namespace internal
107 
115 template <class BoundingVolume>
117  const std::string& resource_path, const coal::Vec3s& scale,
118  const shared_ptr<BVHModel<BoundingVolume> >& polyhedron) {
119  internal::Loader scene;
120  scene.load(resource_path);
121 
122  internal::meshFromAssimpScene(scale, scene.scene, polyhedron);
123 }
124 
125 } // namespace coal
126 
127 #endif // COAL_MESH_LOADER_ASSIMP_H
A class describing the bounding hierarchy of a mesh model or a point cloud model (which is viewed as ...
Definition: BVH_model.h:321
#define COAL_DLLAPI
Definition: config.hh:88
#define COAL_THROW_PRETTY(message, exception)
Definition: fwd.hh:64
Definition: assimp.h:47
void meshFromAssimpScene(const coal::Vec3s &scale, const aiScene *scene, const shared_ptr< BVHModel< BoundingVolume > > &mesh)
Convert an assimp scene to a mesh.
Definition: assimp.h:89
void buildMesh(const coal::Vec3s &scale, const aiScene *scene, unsigned vertices_offset, TriangleAndVertices &tv)
Recursive procedure for building a mesh.
Main namespace.
Definition: broadphase_bruteforce.h:44
Eigen::Matrix< Scalar, 3, 1 > Vec3s
Definition: data_types.h:70
void loadPolyhedronFromResource(const std::string &resource_path, const coal::Vec3s &scale, const shared_ptr< BVHModel< BoundingVolume > > &polyhedron)
Read a mesh file and convert it to a polyhedral mesh.
Definition: assimp.h:116
@ BVH_OK
Definition: BVH_internal.h:64
Definition: assimp.h:60
Assimp::Importer * importer
Definition: assimp.h:66
aiScene const * scene
Definition: assimp.h:67
void load(const std::string &resource_path)
std::vector< coal::Triangle > triangles_
Definition: assimp.h:57
std::vector< coal::Vec3s > vertices_
Definition: assimp.h:56