BALL
1.4.79
|
#include <BALL/STRUCTURE/graphEdge.h>
Public Member Functions | |
Constructors and Destructors | |
GraphTriangle () | |
GraphTriangle (const GraphTriangle< Vertex, Edge, Face > &face, bool deep=false) | |
GraphTriangle (Vertex *vertex1, Vertex *vertex2, Vertex *vertex3, Edge *edge1, Edge *edge2, Edge *edge3, Index index) | |
virtual | ~GraphTriangle () |
Assignment | |
void | set (const GraphTriangle< Vertex, Edge, Face > &face, bool deep=false) |
GraphTriangle< Vertex, Edge, Face > & | operator= (const GraphTriangle< Vertex, Edge, Face > &face) |
void | set (Vertex *vertex1, Vertex *vertex2, Vertex *vertex3, Edge *edge1, Edge *edge2, Edge *edge3, Index index) |
Accessors | |
void | setVertex (Position i, Vertex *vertex) throw (Exception::IndexOverflow) |
Vertex * | getVertex (Position i) const throw (Exception::IndexOverflow) |
void | setEdge (Position i, Edge *edge) throw (Exception::IndexOverflow) |
Edge * | getEdge (Position i) const throw (Exception::IndexOverflow) |
void | setIndex (Index index) |
Index | getIndex () const |
bool | getEdges (const Vertex *vertex, Edge *&edge1, Edge *&edge2) const |
bool | getEdge (const Vertex *vertex1, const Vertex *vertex2, Edge *&edge) const |
Index | getSimilarEdge (const Edge *edge, Edge *&similar_edge) const |
Index | getRelativeIndex (const Vertex *vertex) const |
Index | getRelativeIndex (const Edge *edge) const |
Vertex * | third (const Vertex *v1, const Vertex *v2) const |
Edge * | third (const Edge *e1, const Edge *e2) const |
Edge * | getOppositeEdge (const Vertex *vertex) const |
Vertex * | getOppositeVertex (const Edge *edge) const |
bool | substitute (const Vertex *old_vertex, Vertex *new_vertex) |
bool | substitute (const Edge *old_edge, Edge *new_edge) |
Predicates | |
virtual bool | operator== (const Face &) const |
virtual bool | operator!= (const Face &) const |
virtual bool | operator*= (const Face &) const |
Vertex * | has (Vertex *vertex) const |
Edge * | has (Edge *edge) const |
Protected Attributes | |
Vertex * | vertex_ [3] |
Edge * | edge_ [3] |
Index | index_ |
Friends | |
Class friends | |
| |
class | GraphVertex< Vertex, Edge, Face > |
class | GraphEdge< Vertex, Edge, Face > |
Generic GraphTriangle Class.
Definition at line 24 of file graphEdge.h.
BALL::GraphTriangle< Vertex, Edge, Face >::GraphTriangle | ( | ) |
Default constructor. This method creates a new GraphTriangle object.
Definition at line 901 of file graphFace.h.
BALL::GraphTriangle< Vertex, Edge, Face >::GraphTriangle | ( | const GraphTriangle< Vertex, Edge, Face > & | face, |
bool | deep = false |
||
) |
Copy constructor. Create a new GraphTriangle object from another.
face | the GraphTriangle object to be copied |
deep | if deep = false, all pointers are set to NULL (default). Otherwise the new GraphTriangle object is linked to the neighbours of the old GraphTriangle object. |
Definition at line 915 of file graphFace.h.
BALL::GraphTriangle< Vertex, Edge, Face >::GraphTriangle | ( | Vertex * | vertex1, |
Vertex * | vertex2, | ||
Vertex * | vertex3, | ||
Edge * | edge1, | ||
Edge * | edge2, | ||
Edge * | edge3, | ||
Index | index | ||
) |
Detailled constructor. Create a new GraphTriangle object from some nice objects
vertex1 | assigned to the first vertex |
vertex2 | assigned to the second vertex |
vertex3 | assigned to the third vertex |
edge1 | assigned to the first edge |
edge2 | assigned to the second edge |
edge3 | assigned to the third edge |
index | assigned to the index |
Definition at line 941 of file graphFace.h.
|
virtual |
Destructor. Destructs the GraphTriangle object.
Definition at line 956 of file graphFace.h.
Edge * BALL::GraphTriangle< Vertex, Edge, Face >::getEdge | ( | Position | i | ) | const |
throw | ( | Exception::IndexOverflow | |||
) |
Return one of the edges of the GraphTriangle.
i | the relative index of the edge which should be given back. If i is greater than three, an exception is thrown. |
Definition at line 1070 of file graphFace.h.
bool BALL::GraphTriangle< Vertex, Edge, Face >::getEdge | ( | const Vertex * | vertex1, |
const Vertex * | vertex2, | ||
Edge *& | edge | ||
) | const |
Find the edge of the GraphTriangle that belongs to the two given vertices.
vertex1 | a pointer to the first given vertex |
vertex2 | a pointer to the second given vertex |
edge | a pointer to the found edge |
Definition at line 1142 of file graphFace.h.
bool BALL::GraphTriangle< Vertex, Edge, Face >::getEdges | ( | const Vertex * | vertex, |
Edge *& | edge1, | ||
Edge *& | edge2 | ||
) | const |
Find the two edges of the GraphTriangle that belong to the given vertex.
vertex | a pointer to the given vertex |
edge1 | a pointer to the first found edge |
edge2 | a pointer to the second found edge |
Definition at line 1100 of file graphFace.h.
Index BALL::GraphTriangle< Vertex, Edge, Face >::getIndex | ( | ) | const |
Return the index of the GraphTriangle.
Definition at line 1092 of file graphFace.h.
Edge * BALL::GraphTriangle< Vertex, Edge, Face >::getOppositeEdge | ( | const Vertex * | vertex | ) | const |
Get the edge of the GraphFace which lies on the opposite side of the given vertex.
vertex | a pointer to a vertex of the GraphTriangle |
Definition at line 1267 of file graphFace.h.
Vertex * BALL::GraphTriangle< Vertex, Edge, Face >::getOppositeVertex | ( | const Edge * | edge | ) | const |
Get the vertex of the GraphFace which lies on the opposite side of the given edge.
edge | a pointer to an edge of the GraphTriangle |
Definition at line 1283 of file graphFace.h.
Index BALL::GraphTriangle< Vertex, Edge, Face >::getRelativeIndex | ( | const Vertex * | vertex | ) | const |
Return the relative index of a vertex in the GraphTriangle.
Definition at line 1193 of file graphFace.h.
Index BALL::GraphTriangle< Vertex, Edge, Face >::getRelativeIndex | ( | const Edge * | edge | ) | const |
Return the relative index of an edge in the GraphTriangle.
Definition at line 1208 of file graphFace.h.
Index BALL::GraphTriangle< Vertex, Edge, Face >::getSimilarEdge | ( | const Edge * | edge, |
Edge *& | similar_edge | ||
) | const |
Find the edge of the GraphFace that is similar to the given edge.
edge | a pointer to the given edge |
similar_edge | a pointer to the similar edge of te GraphFace if it can be found, otherwise NULL |
Definition at line 1169 of file graphFace.h.
Vertex * BALL::GraphTriangle< Vertex, Edge, Face >::getVertex | ( | Position | i | ) | const |
throw | ( | Exception::IndexOverflow | |||
) |
Return one of the vertices of the GraphTriangle.
i | the relative index of the vertex which should be given back. If i is greater than three, an exception is thrown. |
Definition at line 1040 of file graphFace.h.
Vertex * BALL::GraphTriangle< Vertex, Edge, Face >::has | ( | Vertex * | vertex | ) | const |
Test whether a vertex is meber of the face.
vertex | a pointer to the the vertex to test |
Definition at line 1351 of file graphFace.h.
Edge * BALL::GraphTriangle< Vertex, Edge, Face >::has | ( | Edge * | edge | ) | const |
Test whether an edge is meber of the face.
edge | a pointer to the edge to test |
Definition at line 1370 of file graphFace.h.
|
virtual |
Inequality operator.
Reimplemented in BALL::RSFace, and BALL::Triangle.
Definition at line 1337 of file graphFace.h.
|
virtual |
Similarity operator.
Reimplemented in BALL::RSFace, and BALL::Triangle.
Definition at line 1344 of file graphFace.h.
GraphTriangle< Vertex, Edge, Face > & BALL::GraphTriangle< Vertex, Edge, Face >::operator= | ( | const GraphTriangle< Vertex, Edge, Face > & | face | ) |
Assign from another GraphTriangle. The GraphTriangle object is linked to the neighbours of the GraphTriangle object to assifgn from.
face | the GraphTriangle object to assign from |
Definition at line 992 of file graphFace.h.
|
virtual |
Equality operator.
Reimplemented in BALL::RSFace, and BALL::Triangle.
Definition at line 1330 of file graphFace.h.
void BALL::GraphTriangle< Vertex, Edge, Face >::set | ( | const GraphTriangle< Vertex, Edge, Face > & | face, |
bool | deep = false |
||
) |
Assign from another GraphTriangle.
face | the GraphTriangle object to assign from |
deep | if deep = false, all pointers are set to NULL (default). Otherwise the GraphTriangle object is linked to the neighbours of the GraphTriangle object to assign from. |
Definition at line 963 of file graphFace.h.
void BALL::GraphTriangle< Vertex, Edge, Face >::set | ( | Vertex * | vertex1, |
Vertex * | vertex2, | ||
Vertex * | vertex3, | ||
Edge * | edge1, | ||
Edge * | edge2, | ||
Edge * | edge3, | ||
Index | index | ||
) |
Assign to a lot of nice objects
vertex1 | assigned to the first vertex |
vertex2 | assigned to the second vertex |
vertex3 | assigned to the third vertex |
edge1 | assigned to the first edge |
edge2 | assigned to the second edge |
edge3 | assigned to the third edge |
index | assigned to the index |
Definition at line 1010 of file graphFace.h.
void BALL::GraphTriangle< Vertex, Edge, Face >::setEdge | ( | Position | i, |
Edge * | edge | ||
) | |||
throw | ( | Exception::IndexOverflow | |
) |
Set one of the edges of the GraphTriangle.
i | the relative index of the edge which should be set. If i is greater than three, an exception is thrown. |
edge | a pointer to the new edge |
Definition at line 1055 of file graphFace.h.
void BALL::GraphTriangle< Vertex, Edge, Face >::setIndex | ( | Index | index | ) |
Set the index of the GraphTriangle.
index | the new index |
Definition at line 1085 of file graphFace.h.
void BALL::GraphTriangle< Vertex, Edge, Face >::setVertex | ( | Position | i, |
Vertex * | vertex | ||
) | |||
throw | ( | Exception::IndexOverflow | |
) |
Set one of the vertices of the GraphTriangle.
i | the relative index of the vertex which should be set. If i is greater three, an exception is thrown. |
vertex | a pointer to the new vertex |
Definition at line 1025 of file graphFace.h.
bool BALL::GraphTriangle< Vertex, Edge, Face >::substitute | ( | const Vertex * | old_vertex, |
Vertex * | new_vertex | ||
) |
Substitute a vertex by an other one.
old_vertex | the vertex that has to be substituted |
new_vertex | the new vertex |
Definition at line 1299 of file graphFace.h.
bool BALL::GraphTriangle< Vertex, Edge, Face >::substitute | ( | const Edge * | old_edge, |
Edge * | new_edge | ||
) |
Substitute an edge by an other one.
old_edge | the edge that has to be substituted |
new_edge | the new edge |
Definition at line 1315 of file graphFace.h.
Vertex * BALL::GraphTriangle< Vertex, Edge, Face >::third | ( | const Vertex * | v1, |
const Vertex * | v2 | ||
) | const |
Return a pointer to the third vertex of the GraphTriangle.
v1 | a pointer to the first vertex |
v2 | a pointer to the second vertex |
Definition at line 1223 of file graphFace.h.
Edge * BALL::GraphTriangle< Vertex, Edge, Face >::third | ( | const Edge * | e1, |
const Edge * | e2 | ||
) | const |
Return a pointer to the third edge of the GraphTriangle.
e1 | a pointer to the first edge |
e2 | a pointer to the second edge |
Definition at line 1245 of file graphFace.h.
|
friend |
Definition at line 635 of file graphFace.h.
|
friend |
Definition at line 634 of file graphFace.h.
|
protected |
Definition at line 891 of file graphFace.h.
|
protected |
Definition at line 894 of file graphFace.h.
|
protected |
Definition at line 888 of file graphFace.h.