Coin
4.0.3
Coin3D core library
|
The SoBoundingBoxCache class is used to cache bounding boxes. More...
#include <Inventor/caches/SoBoundingBoxCache.h>
Public Member Functions | |
SoBoundingBoxCache (SoState *state) | |
virtual | ~SoBoundingBoxCache () |
const SbXfBox3f & | getBox () const |
const SbVec3f & | getCenter () const |
const SbBox3f & | getProjectedBox () const |
SbBool | hasLinesOrPoints (void) const |
SbBool | isCenterSet () const |
void | set (const SbXfBox3f &boundingbox, SbBool centerset, const SbVec3f ¢erpoint) |
Public Member Functions inherited from SoCache | |
SoCache (SoState *const state) | |
virtual void | addCacheDependency (const SoState *state, SoCache *cache) |
void | addElement (const SoElement *const elem) |
const SoElement * | getInvalidElement (const SoState *const state) const |
void | invalidate (void) |
virtual SbBool | isValid (const SoState *state) const |
void | ref (void) |
void | unref (SoState *state=NULL) |
Static Public Member Functions | |
static void | setHasLinesOrPoints (SoState *state) |
Additional Inherited Members | |
Protected Member Functions inherited from SoCache | |
virtual | ~SoCache () |
virtual void | destroy (SoState *state) |
The SoBoundingBoxCache class is used to cache bounding boxes.
SoBoundingBoxCache::SoBoundingBoxCache | ( | SoState * | state | ) |
Constructor with state being the current state.
|
virtual |
Destructor.
Returns the bounding box for this cache.
Returns the center of the bounding box. Should only be used if SoBoundingBoxCache::isCenterSet() returns TRUE
.
Returns the projected bounding box for this cache.
SbBool SoBoundingBoxCache::hasLinesOrPoints | ( | void | ) | const |
Return TRUE
if the hasLinesOrPoints flag has been set.
SbBool SoBoundingBoxCache::isCenterSet | ( | void | ) | const |
Returns whether the center of the bounding box was set in the SoBoundingBoxCache::set() method.
void SoBoundingBoxCache::set | ( | const SbXfBox3f & | boundingbox, |
SbBool | centerset, | ||
const SbVec3f & | centerpoint ) |
Sets the data for this cache. boundingBox is the node's bounding box, centerSet and centerPoints specifies the center of the geometry inside boundingBox.
Sets the flag returned from SoBoundingBoxCache::hasLinesOrPoints() to TRUE
for all open bounding box caches.
The reason bounding box caches keep a lines-or-points flag is to make it known to client code if the shape(s) they contain have any of these primitives – or are rendered with these primitives. The reason this is important to know for the client code is because it might need to add an "epsilon" slack value to the calculated bounding box to account for smoothing / anti-aliasing effects in the renderer, so line and point graphics are not accidentally clipped by near and far clipping planes, for instance.
This method is a static method on the class. It will upon invocation scan through the state stack and set the flag for all open SoBoundingBoxCache elements. It has been made to work like this so it can easily be invoked on all current bounding box cache instances from the SoShape-type nodes using lines and / or point primitives.