Open CASCADE Technology
7.1.0.beta
|
Stores parameters of bounding volume hierarchy (BVH). Bounding volume hierarchy (BVH) organizes geometric objects in the tree based on spatial relationships. Each node in the tree contains an axis-aligned bounding box of all the objects below it. Bounding volume hierarchies are used in many algorithms to support efficient operations on the sets of geometric objects, such as collision detection, ray-tracing, searching of nearest objects, and view frustum culling. More...
#include <BVH_Tree.hxx>
Public Types | |
custom data types | |
typedef BVH_Box< T, N >::BVH_VecNt | BVH_VecNt |
Public Member Functions | |
general methods | |
BVH_TreeBase () | |
Creates new empty BVH tree. More... | |
virtual | ~BVH_TreeBase () |
Releases resources of BVH tree. More... | |
int | Depth () const |
Returns depth (height) of BVH tree. More... | |
int | Length () const |
Returns total number of BVH tree nodes. More... | |
methods for accessing individual nodes | |
BVH_VecNt & | MinPoint (const int theNodeIndex) |
Returns minimum point of the given node. More... | |
BVH_VecNt & | MaxPoint (const int theNodeIndex) |
Returns maximum point of the given node. More... | |
const BVH_VecNt & | MinPoint (const int theNodeIndex) const |
Returns minimum point of the given node. More... | |
const BVH_VecNt & | MaxPoint (const int theNodeIndex) const |
Returns maximum point of the given node. More... | |
int & | BegPrimitive (const int theNodeIndex) |
Returns index of first primitive of the given leaf node. More... | |
int & | EndPrimitive (const int theNodeIndex) |
Returns index of last primitive of the given leaf node. More... | |
int | BegPrimitive (const int theNodeIndex) const |
Returns index of first primitive of the given leaf node. More... | |
int | EndPrimitive (const int theNodeIndex) const |
Returns index of last primitive of the given leaf node. More... | |
int | NbPrimitives (const int theNodeIndex) const |
Returns number of primitives in the given leaf node. More... | |
int & | Level (const int theNodeIndex) |
Returns level (depth) of the given node. More... | |
int | Level (const int theNodeIndex) const |
Returns level (depth) of the given node. More... | |
bool | IsOuter (const int theNodeIndex) const |
Checks whether the given node is outer. More... | |
methods for accessing serialized tree data | |
BVH_Array4i & | NodeInfoBuffer () |
Returns array of node data records. More... | |
const BVH_Array4i & | NodeInfoBuffer () const |
Returns array of node data records. More... | |
BVH::ArrayType< T, N >::Type & | MinPointBuffer () |
Returns array of node minimum points. More... | |
BVH::ArrayType< T, N >::Type & | MaxPointBuffer () |
Returns array of node maximum points. More... | |
const BVH::ArrayType< T, N >::Type & | MinPointBuffer () const |
Returns array of node minimum points. More... | |
const BVH::ArrayType< T, N >::Type & | MaxPointBuffer () const |
Returns array of node maximum points. More... | |
Data Fields | |
protected fields | |
BVH_Array4i | myNodeInfoBuffer |
Array of node data records. More... | |
BVH::ArrayType< T, N >::Type | myMinPointBuffer |
Array of node minimum points. More... | |
BVH::ArrayType< T, N >::Type | myMaxPointBuffer |
Array of node maximum points. More... | |
int | myDepth |
Current depth of BVH tree (set by builder). More... | |
Stores parameters of bounding volume hierarchy (BVH). Bounding volume hierarchy (BVH) organizes geometric objects in the tree based on spatial relationships. Each node in the tree contains an axis-aligned bounding box of all the objects below it. Bounding volume hierarchies are used in many algorithms to support efficient operations on the sets of geometric objects, such as collision detection, ray-tracing, searching of nearest objects, and view frustum culling.
typedef BVH_Box<T, N>::BVH_VecNt BVH_TreeBase< T, N >::BVH_VecNt |
|
inline |
Creates new empty BVH tree.
|
virtual |
Releases resources of BVH tree.
|
inline |
Returns index of first primitive of the given leaf node.
|
inline |
Returns index of first primitive of the given leaf node.
|
inline |
Returns depth (height) of BVH tree.
|
inline |
Returns index of last primitive of the given leaf node.
|
inline |
Returns index of last primitive of the given leaf node.
|
inline |
Checks whether the given node is outer.
|
inline |
Returns total number of BVH tree nodes.
|
inline |
Returns level (depth) of the given node.
|
inline |
Returns level (depth) of the given node.
|
inline |
Returns maximum point of the given node.
|
inline |
Returns maximum point of the given node.
|
inline |
Returns array of node maximum points.
|
inline |
Returns array of node maximum points.
|
inline |
Returns minimum point of the given node.
|
inline |
Returns minimum point of the given node.
|
inline |
Returns array of node minimum points.
|
inline |
Returns array of node minimum points.
|
inline |
Returns number of primitives in the given leaf node.
|
inline |
Returns array of node data records.
|
inline |
Returns array of node data records.
int BVH_TreeBase< T, N >::myDepth |
Current depth of BVH tree (set by builder).
BVH::ArrayType<T, N>::Type BVH_TreeBase< T, N >::myMaxPointBuffer |
Array of node maximum points.
BVH::ArrayType<T, N>::Type BVH_TreeBase< T, N >::myMinPointBuffer |
Array of node minimum points.
BVH_Array4i BVH_TreeBase< T, N >::myNodeInfoBuffer |
Array of node data records.