Main MRPT website > C++ reference for MRPT 1.9.9
Classes | Enumerations | Functions
CPolyhedron.cpp File Reference
#include "opengl-precomp.h"
#include <mrpt/opengl/CPolyhedron.h>
#include <mrpt/math/CMatrixTemplate.h>
#include <mrpt/math/CMatrix.h>
#include <mrpt/poses/CPose3D.h>
#include <mrpt/math/geometry.h>
#include <mrpt/math/ops_containers.h>
#include <mrpt/random.h>
#include <mrpt/serialization/CArchive.h>
#include <mrpt/serialization/stl_serialization.h>
#include "opengl_internals.h"
Include dependency graph for CPolyhedron.cpp:

Go to the source code of this file.

Classes

class  FCreatePolygonFromFace< T >
 
struct  SegmentVector
 

Enumerations

enum  JohnsonBodyPart {
  INF_NO_BODY = -2, SUP_NO_BODY = -1, UPWARDS_PYRAMID = 0, DOWNWARDS_PYRAMID = 1,
  UPWARDS_CUPOLA = 2, DOWNWARDS_CUPOLA = 3, ROTATED_UPWARDS_CUPOLA = 4, ROTATED_DOWNWARDS_CUPOLA = 5,
  PRISM = 6, ANTIPRISM = 7, UPWARDS_ROTUNDA = 8, DOWNWARDS_ROTUNDA = 9,
  ROTATED_UPWARDS_ROTUNDA = 10, ROTATED_DOWNWARDS_ROTUNDA = 11
}
 

Functions

bool getVerticesAndFaces (const vector< math::TPolygon3D > &polys, vector< TPoint3D > &vertices, vector< CPolyhedron::TPolyhedronFace > &faces)
 
bool analyzeJohnsonPartsString (const std::string &components, uint32_t numBaseEdges, vector< JohnsonBodyPart > &parts)
 
size_t additionalVertices (JohnsonBodyPart j, uint32_t numBaseEdges)
 
void insertCupola (size_t numBaseEdges, double angleShift, double baseRadius, double edgeLength, bool isRotated, bool isUpwards, size_t base, vector< TPoint3D > &verts, vector< CPolyhedron::TPolyhedronFace > &faces)
 
void insertRotunda (double angleShift, double baseRadius, bool isRotated, bool isUpwards, size_t base, vector< TPoint3D > &verts, vector< CPolyhedron::TPolyhedronFace > &faces)
 
size_t additionalFaces (JohnsonBodyPart j, uint32_t numBaseEdges)
 
bool faceContainsEdge (const CPolyhedron::TPolyhedronFace &f, const CPolyhedron::TPolyhedronEdge &e)
 
bool getPlanesIntersection (const vector< const TPlane * > &planes, TPoint3D &pnt)
 
bool searchForFace (const vector< CPolyhedron::TPolyhedronFace > &fs, uint32_t v1, uint32_t v2, uint32_t v3)
 
bool searchForEdge (const vector< CPolyhedron::TPolyhedronEdge > &es, uint32_t v1, uint32_t v2, size_t &where)
 
bool searchForEdge (const vector< CPolyhedron::TPolyhedronFace >::const_iterator &begin, const vector< CPolyhedron::TPolyhedronFace >::const_iterator &end, uint32_t v1, uint32_t v2)
 
double getHeight (const TPolygon3D &p, const TPoint3D &c)
 

Enumeration Type Documentation

◆ JohnsonBodyPart

Enumerator
INF_NO_BODY 
SUP_NO_BODY 
UPWARDS_PYRAMID 
DOWNWARDS_PYRAMID 
UPWARDS_CUPOLA 
DOWNWARDS_CUPOLA 
ROTATED_UPWARDS_CUPOLA 
ROTATED_DOWNWARDS_CUPOLA 
PRISM 
ANTIPRISM 
UPWARDS_ROTUNDA 
DOWNWARDS_ROTUNDA 
ROTATED_UPWARDS_ROTUNDA 
ROTATED_DOWNWARDS_ROTUNDA 

Definition at line 79 of file CPolyhedron.cpp.

Function Documentation

◆ additionalFaces()

size_t additionalFaces ( JohnsonBodyPart  j,
uint32_t  numBaseEdges 
)
inline

◆ additionalVertices()

size_t additionalVertices ( JohnsonBodyPart  j,
uint32_t  numBaseEdges 
)
inline

◆ analyzeJohnsonPartsString()

bool analyzeJohnsonPartsString ( const std::string components,
uint32_t  numBaseEdges,
vector< JohnsonBodyPart > &  parts 
)

◆ faceContainsEdge()

bool faceContainsEdge ( const CPolyhedron::TPolyhedronFace f,
const CPolyhedron::TPolyhedronEdge e 
)
inline

◆ getHeight()

double getHeight ( const TPolygon3D p,
const TPoint3D c 
)

◆ getPlanesIntersection()

bool getPlanesIntersection ( const vector< const TPlane * > &  planes,
TPoint3D pnt 
)

Definition at line 353 of file CPolyhedron.cpp.

References mrpt::math::intersect().

Referenced by mrpt::opengl::CPolyhedron::getDual().

◆ getVerticesAndFaces()

bool getVerticesAndFaces ( const vector< math::TPolygon3D > &  polys,
vector< TPoint3D > &  vertices,
vector< CPolyhedron::TPolyhedronFace > &  faces 
)

◆ insertCupola()

void insertCupola ( size_t  numBaseEdges,
double  angleShift,
double  baseRadius,
double  edgeLength,
bool  isRotated,
bool  isUpwards,
size_t  base,
vector< TPoint3D > &  verts,
vector< CPolyhedron::TPolyhedronFace > &  faces 
)

◆ insertRotunda()

void insertRotunda ( double  angleShift,
double  baseRadius,
bool  isRotated,
bool  isUpwards,
size_t  base,
vector< TPoint3D > &  verts,
vector< CPolyhedron::TPolyhedronFace > &  faces 
)

◆ searchForEdge() [1/2]

bool searchForEdge ( const vector< CPolyhedron::TPolyhedronEdge > &  es,
uint32_t  v1,
uint32_t  v2,
size_t &  where 
)

◆ searchForEdge() [2/2]

bool searchForEdge ( const vector< CPolyhedron::TPolyhedronFace >::const_iterator begin,
const vector< CPolyhedron::TPolyhedronFace >::const_iterator end,
uint32_t  v1,
uint32_t  v2 
)

Definition at line 428 of file CPolyhedron.cpp.

References begin().

◆ searchForFace()

bool searchForFace ( const vector< CPolyhedron::TPolyhedronFace > &  fs,
uint32_t  v1,
uint32_t  v2,
uint32_t  v3 
)

Definition at line 391 of file CPolyhedron.cpp.

Referenced by mrpt::opengl::CPolyhedron::truncate().




Page generated by Doxygen 1.8.17 for MRPT 1.9.9 Git: ad3a9d8ae Tue May 1 23:10:22 2018 -0700 at miƩ 12 jul 2023 10:03:34 CEST