Description
Base interface class for convex decomposition.
#include <ChConvexDecomposition.h>
Public Member Functions | |
ChConvexDecomposition () | |
Basic constructor. | |
virtual | ~ChConvexDecomposition () |
Destructor. | |
virtual void | Reset (void)=0 |
Reset the input mesh data. | |
virtual bool | AddTriangle (const ChVector3d &v1, const ChVector3d &v2, const ChVector3d &v3)=0 |
Add a triangle, by passing three points for vertexes. More... | |
virtual bool | AddTriangle (const ChTriangle &t1) |
Add a triangle, by passing a ChTriangle object (that will be copied, not referenced). More... | |
virtual bool | AddTriangleMesh (const ChTriangleMesh &tm) |
Add a triangle mesh, by passing an entire ChTriangleMesh object. More... | |
virtual int | ComputeConvexDecomposition ()=0 |
Perform the convex decomposition. | |
virtual unsigned int | GetHullCount ()=0 |
Get the number of computed hulls after the convex decomposition. | |
virtual bool | GetConvexHullResult (unsigned int hullIndex, ChTriangleMesh &convextrimesh)=0 |
Get the n-th computed convex hull, by filling a ChTriangleMesh object that is passed as a parameter. | |
virtual bool | GetConvexHullResult (unsigned int hullIndex, std::vector< ChVector3d > &convexhull)=0 |
Get the n-th computed convex hull, by filling a vector of points of the vertexes of the n-th hull that is passed as a parameter. | |
virtual bool | WriteConvexHullsAsChullsFile (std::ostream &mstream) |
Write the convex decomposition to a ".chulls" file, where each hull is a sequence of x y z coords. More... | |
virtual void | WriteConvexHullsAsWavefrontObj (std::ostream &mstream)=0 |
Save the computed convex hulls as a Wavefront file using the '.obj' fileformat, with each hull as a separate group. More... | |
Member Function Documentation
◆ AddTriangle() [1/2]
|
virtual |
Add a triangle, by passing a ChTriangle object (that will be copied, not referenced).
Note: the vertexes must be properly ordered (oriented triangle, normal pointing outside)
◆ AddTriangle() [2/2]
|
pure virtual |
Add a triangle, by passing three points for vertexes.
Note: the vertexes must be properly ordered (oriented triangle, normal pointing outside)
Implemented in chrono::ChConvexDecompositionHACDv2, and chrono::ChConvexDecompositionHACD.
◆ AddTriangleMesh()
|
virtual |
Add a triangle mesh, by passing an entire ChTriangleMesh object.
Note: the triangles must define closed volumes (holes, gaps in edges, etc. may trouble the decomposition)
Reimplemented in chrono::ChConvexDecompositionHACDv2, and chrono::ChConvexDecompositionHACD.
◆ WriteConvexHullsAsChullsFile()
|
virtual |
Write the convex decomposition to a ".chulls" file, where each hull is a sequence of x y z coords.
Can throw exceptions.
◆ WriteConvexHullsAsWavefrontObj()
|
pure virtual |
Save the computed convex hulls as a Wavefront file using the '.obj' fileformat, with each hull as a separate group.
May throw exceptions if file locked etc.
Implemented in chrono::ChConvexDecompositionHACDv2, and chrono::ChConvexDecompositionHACD.
The documentation for this class was generated from the following files:
- /builds/uwsbel/chrono/src/chrono/collision/ChConvexDecomposition.h
- /builds/uwsbel/chrono/src/chrono/collision/ChConvexDecomposition.cpp