Rhino C++ API
8.13
|
#include <opennurbs_plus_x.h>
Public Member Functions | |
ON_MESH_POINT () | |
bool | GetTriangle (int &idxA, int &idxB, int &idxC) const |
bool | GetTriangle (ON_3dPoint &ptA, ON_3dPoint &ptB, ON_3dPoint &ptC) const |
bool | IsValid (ON_TextLog *text_log) const |
bool | SetEdgePoint (const ON_Mesh *mesh, int fi, int ei, double et) |
bool | SetFacePoint (const class ON_Mesh *mesh, int fi, const double t[4]) |
ON_COMPONENT_INDEX | SetTopologyComponentIndex (double *edge_parameter) |
Public Attributes | |
ON_COMPONENT_INDEX | m_ci |
int | m_edge_index |
double | m_et |
m_et = edge parameter when m_ci refers to an edge. More... | |
int | m_face_index |
const ON_Mesh * | m_mesh |
const class ON_MeshTreeNode * | m_mnode |
can be null More... | |
ON_3dPoint | m_P |
3d location More... | |
unsigned int | m_sn |
ON_MESH_POINT serial number. More... | |
double | m_t [4] |
char | m_Triangle |
ON_MESH_POINT::ON_MESH_POINT | ( | ) |
bool ON_MESH_POINT::GetTriangle | ( | int & | idxA, |
int & | idxB, | ||
int & | idxC | ||
) | const |
Gets the mesh face indices of the triangle where the intersection is on the face takes into consideration the way the quad was split during the intersection
bool ON_MESH_POINT::GetTriangle | ( | ON_3dPoint & | ptA, |
ON_3dPoint & | ptB, | ||
ON_3dPoint & | ptC | ||
) | const |
bool ON_MESH_POINT::IsValid | ( | ON_TextLog * | text_log | ) | const |
bool ON_MESH_POINT::SetEdgePoint | ( | const ON_Mesh * | mesh, |
int | fi, | ||
int | ei, | ||
double | et | ||
) |
Description: Sets the m_mesh, m_et, m_ci, m_edge_index, m_face_index, m_t, and m_P fields. Parameters: m_mesh - [in] fi - [in] index of the face the topology's m_topf[] array (which is parallel to the mesh's m_F[] array) ei - [in] index of edge in the topology's m_tope[] array et - [in] edge parameter 0.0 <= et <= 1.0 Returns: True if the input is valid and the fields are set. Calling SetEdgePoint with ei == 0 or ei == 1.0 will set ON_MESH_POINT::m_ci.m_type to ON_COMPONENT_INDEX::meshtop_vertex and ON_MESH_POINT::m_ci.m_index to the mesh topology vertex index of the vertex at the start or end of the edge.
bool ON_MESH_POINT::SetFacePoint | ( | const class ON_Mesh * | mesh, |
int | fi, | ||
const double | t[4] | ||
) |
Description: Sets the m_mesh, m_et, m_ci, m_edge_index, m_face_index, m_t, and m_P fields. Parameters: m_mesh - [in] fi - [in] index of the face t - [in] barycentric coordinates of the point. All t[i] must be >= 0.0, <= 1.0, and t[0]+t[1]+t[2]+t[3] must be within ON_ZERO_TOLERANCE of 1.0. Returns: True if the input is valid and the fields are set. Remarks: Calling SetFacePoint with 1 non-zero barycentric coordinate will set ON_MESH_POINT::m_ci.m_type to ON_COMPONENT_INDEX::meshtop_vertex and ON_MESH_POINT::m_ci.m_index to the mesh topology vertex index of the vertex at the referenced corner of the face. And will set m_edge_index to the mesh topology index of the edge preceding that vertex and will set m_et to 0.0 or 1.0
ON_COMPONENT_INDEX ON_MESH_POINT::SetTopologyComponentIndex | ( | double * | edge_parameter | ) |
Description: Set the topological component of the this mesh point. Parameters: edge_parameter - [out] optional - can be nullptr If the component is an edge, then *edge_parameter is set (0 < *edge_parameter < 1). If the component is not an edge, then *edge_parameter is set to ON_UNSET_VALUE. Returns: Component index of the topological component.
ON_COMPONENT_INDEX ON_MESH_POINT::m_ci |
int ON_MESH_POINT::m_edge_index |
The constructor sets m_edge_index and m_face_index to -1, however when ON_MESH_POINT is used in an ON_SimpleArray<>, unused points will have a "default" values of 0.
When set, m_edge_index is an index of an edge in m_mesh->Topology().m_tope[] and m_face_index is an index of a face in m_mesh->Topology().m_topf[]. The the m_mesh->Topology().m_topf[] and m_mesh->m_F[] arrays are parallel, m_face_index is also the index of the face in m_mesh->m_F[].
The m_face_index field must always be set. When m_ci refers to a vertex, any face that uses the vertex may appear as m_face_index. When m_ci refers to an edge or m_edge_index is set, then any face that uses that edge may appear as m_face_index.
double ON_MESH_POINT::m_et |
m_et = edge parameter when m_ci refers to an edge.
int ON_MESH_POINT::m_face_index |
const ON_Mesh* ON_MESH_POINT::m_mesh |
const class ON_MeshTreeNode* ON_MESH_POINT::m_mnode |
can be null
ON_3dPoint ON_MESH_POINT::m_P |
3d location
unsigned int ON_MESH_POINT::m_sn |
ON_MESH_POINT serial number.
double ON_MESH_POINT::m_t[4] |
Barycentric quad coordinates for the point m_P on the mesh face m_mesh->m_F[m_face_index] If the face is a triangle disregard m_t3.
If the face is a quad and is split between vertices 0 and 2, then m_t[3] will be 0.0 when m_P is on the triangle defined by vi[0], vi[1], vi[2], and m_t[1] will be 0.0 when m_P is on the triangle defined by vi[0], vi[2], vi[3].
If the face is a quad and is split between vertices 1 and 3, then m_t[2] will be 0.0 when m_P is on the triangle defined by vi[0], vi[1], vi[3], and m_t[0] will be 0.0 when m_P is on the triangle defined by vi[1], vi[2], vi[3].
char ON_MESH_POINT::m_Triangle |
Face triangle where the intersection takes place; 0 is unset A is 0,1,2 B is 0,2,3 C is 0,1,3 D is 1,2,3