MeshCSG.hh
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2012-2016 Open Source Robotics Foundation
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16 */
17 #ifndef _GAZEBO_MESHCSG_HH_
18 #define _GAZEBO_MESHCSG_HH_
19 
20 #include <ignition/math/Pose3.hh>
21 
22 #include "gazebo/math/Pose.hh"
23 #include "gazebo/util/system.hh"
24 
25 struct _GtsSurface;
26 typedef _GtsSurface GtsSurface;
27 struct _GPtrArray;
28 typedef _GPtrArray GPtrArray;
29 
30 namespace gazebo
31 {
32  namespace common
33  {
34  class Mesh;
35 
38 
41  class GZ_COMMON_VISIBLE MeshCSG
42  {
44  public: enum BooleanOperation {UNION, INTERSECTION, DIFFERENCE};
45 
47  public: MeshCSG();
48 
50  public: virtual ~MeshCSG();
51 
58  public: Mesh *CreateBoolean(const Mesh *_m1, const Mesh *_m2,
59  const int _operation,
60  const ignition::math::Pose3d &_offset = ignition::math::Pose3d::Zero);
61 
63  private: void ConvertMeshToGTS(const Mesh *mesh, GtsSurface *surface);
64 
66  // are within epsilon
69  private: void MergeVertices(GPtrArray * _vertices, double _epsilon);
70  };
72  }
73 }
74 
75 #endif
A 3D mesh.
Definition: Mesh.hh:44
_GtsSurface GtsSurface
Definition: GTSMeshUtils.hh:29
BooleanOperation
An enumeration of the boolean operations.
Definition: MeshCSG.hh:44
Definition: MeshCSG.hh:44
Creates CSG meshes.
Definition: MeshCSG.hh:41
_GPtrArray GPtrArray
Definition: MeshCSG.hh:27
_GtsSurface GtsSurface
Definition: MeshCSG.hh:25