VTK
|
Octree node that has 8 children each of equal size. More...
#include <vtkOctreePointLocatorNode.h>
Public Types | |
typedef vtkObject | Superclass |
Public Member Functions | |
virtual vtkTypeBool | IsA (const char *type) |
Return 1 if this class is the same type of (or a subclass of) the named class. More... | |
vtkOctreePointLocatorNode * | NewInstance () const |
void | PrintSelf (ostream &os, vtkIndent indent) override |
Methods invoked by print to print information about the object including superclasses. More... | |
void | CreateChildNodes () |
Add the 8 children. More... | |
void | DeleteChildNodes () |
Delete the 8 children. More... | |
vtkOctreePointLocatorNode * | GetChild (int i) |
Get a pointer to the ith child of this node. More... | |
int | IntersectsRegion (vtkPlanesIntersection *pi, int useDataBounds) |
A vtkPlanesIntersection object represents a convex 3D region bounded by planes, and it is capable of computing intersections of boxes with itself. More... | |
vtkTypeBool | ContainsPoint (double x, double y, double z, int useDataBounds) |
Return 1 if this spatial region entirely contains the given point. More... | |
double | GetDistance2ToBoundary (double x, double y, double z, vtkOctreePointLocatorNode *top, int useDataBounds) |
Calculate the distance squared from any point to the boundary of this region. More... | |
double | GetDistance2ToBoundary (double x, double y, double z, double *boundaryPt, vtkOctreePointLocatorNode *top, int useDataBounds) |
Calculate the distance squared from any point to the boundary of this region. More... | |
double | GetDistance2ToInnerBoundary (double x, double y, double z, vtkOctreePointLocatorNode *top) |
Calculate the distance from the specified point (which is required to be inside this spatial region) to an interior boundary. More... | |
int | GetSubOctantIndex (double *point, int CheckContainment) |
Return the id of the suboctant that a given point is in. More... | |
void | ComputeOctreeNodeInformation (vtkOctreePointLocatorNode *Parent, int &NextLeafId, int &NextMinId, float *coordinates) |
Recursive function to compute ID, MinVal, MaxVal, and MinID. More... | |
void | SetNumberOfPoints (int numberOfPoints) |
Set/Get the number of points contained in this region. More... | |
virtual int | GetNumberOfPoints () |
Set/Get the number of points contained in this region. More... | |
void | SetBounds (double xMin, double xMax, double yMin, double yMax, double zMin, double zMax) |
Set/Get the bounds of the spatial region represented by this node. More... | |
void | SetBounds (const double b[6]) |
Set/Get the bounds of the spatial region represented by this node. More... | |
void | GetBounds (double *b) const |
Set/Get the bounds of the spatial region represented by this node. More... | |
void | SetDataBounds (double xMin, double xMax, double yMin, double yMax, double zMin, double zMax) |
Set/Get the bounds of the points contained in this spatial region. More... | |
void | GetDataBounds (double *b) const |
Set/Get the bounds of the points contained in this spatial region. More... | |
virtual double * | GetMinBounds () |
Get a pointer to the 3 bound minima (xmin, ymin and zmin) or the 3 bound maxima (xmax, ymax, zmax). More... | |
virtual double * | GetMaxBounds () |
Get a pointer to the 3 bound minima (xmin, ymin and zmin) or the 3 bound maxima (xmax, ymax, zmax). More... | |
void | SetMinBounds (double minBounds[3]) |
Set the xmin, ymin and zmin value of the bounds of this region. More... | |
void | SetMaxBounds (double maxBounds[3]) |
Set the xmax, ymax and zmax value of the bounds of this region. More... | |
virtual double * | GetMinDataBounds () |
Get a pointer to the 3 data bound minima (xmin, ymin and zmin) or the 3 data bound maxima (xmax, ymax, zmax). More... | |
virtual double * | GetMaxDataBounds () |
Get a pointer to the 3 data bound minima (xmin, ymin and zmin) or the 3 data bound maxima (xmax, ymax, zmax). More... | |
void | SetMinDataBounds (double minDataBounds[3]) |
Set the xmin, ymin and zmin value of the bounds of this data within this region. More... | |
void | SetMaxDataBounds (double maxDataBounds[3]) |
Set the xmax, ymax and zmax value of the bounds of this data within this region. More... | |
virtual int | GetID () |
Get the ID associated with the region described by this node. More... | |
virtual int | GetMinID () |
If this node is not a leaf node, there are leaf nodes below it whose regions represent a partitioning of this region. More... | |
Public Member Functions inherited from vtkObject | |
vtkBaseTypeMacro (vtkObject, vtkObjectBase) | |
virtual void | DebugOn () |
Turn debugging output on. More... | |
virtual void | DebugOff () |
Turn debugging output off. More... | |
bool | GetDebug () |
Get the value of the debug flag. More... | |
void | SetDebug (bool debugFlag) |
Set the value of the debug flag. More... | |
virtual void | Modified () |
Update the modification time for this object. More... | |
virtual vtkMTimeType | GetMTime () |
Return this object's modified time. More... | |
void | RemoveObserver (unsigned long tag) |
void | RemoveObservers (unsigned long event) |
void | RemoveObservers (const char *event) |
void | RemoveAllObservers () |
vtkTypeBool | HasObserver (unsigned long event) |
vtkTypeBool | HasObserver (const char *event) |
int | InvokeEvent (unsigned long event) |
int | InvokeEvent (const char *event) |
unsigned long | AddObserver (unsigned long event, vtkCommand *, float priority=0.0f) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
unsigned long | AddObserver (const char *event, vtkCommand *, float priority=0.0f) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
vtkCommand * | GetCommand (unsigned long tag) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
void | RemoveObserver (vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
void | RemoveObservers (unsigned long event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
void | RemoveObservers (const char *event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
vtkTypeBool | HasObserver (unsigned long event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
vtkTypeBool | HasObserver (const char *event, vtkCommand *) |
Allow people to add/remove/invoke observers (callbacks) to any VTK object. More... | |
template<class U , class T > | |
unsigned long | AddObserver (unsigned long event, U observer, void(T::*callback)(), float priority=0.0f) |
Overloads to AddObserver that allow developers to add class member functions as callbacks for events. More... | |
template<class U , class T > | |
unsigned long | AddObserver (unsigned long event, U observer, void(T::*callback)(vtkObject *, unsigned long, void *), float priority=0.0f) |
Overloads to AddObserver that allow developers to add class member functions as callbacks for events. More... | |
template<class U , class T > | |
unsigned long | AddObserver (unsigned long event, U observer, bool(T::*callback)(vtkObject *, unsigned long, void *), float priority=0.0f) |
Allow user to set the AbortFlagOn() with the return value of the callback method. More... | |
int | InvokeEvent (unsigned long event, void *callData) |
This method invokes an event and return whether the event was aborted or not. More... | |
int | InvokeEvent (const char *event, void *callData) |
This method invokes an event and return whether the event was aborted or not. More... | |
Public Member Functions inherited from vtkObjectBase | |
const char * | GetClassName () const |
Return the class name as a string. More... | |
virtual void | Delete () |
Delete a VTK object. More... | |
virtual void | FastDelete () |
Delete a reference to this object. More... | |
void | InitializeObjectBase () |
void | Print (ostream &os) |
Print an object to an ostream. More... | |
virtual void | Register (vtkObjectBase *o) |
Increase the reference count (mark as used by another object). More... | |
virtual void | UnRegister (vtkObjectBase *o) |
Decrease the reference count (release by another object). More... | |
int | GetReferenceCount () |
Return the current reference count of this object. More... | |
void | SetReferenceCount (int) |
Sets the reference count. More... | |
void | PrintRevisions (ostream &) |
Legacy. More... | |
virtual void | PrintHeader (ostream &os, vtkIndent indent) |
Methods invoked by print to print information about the object including superclasses. More... | |
virtual void | PrintTrailer (ostream &os, vtkIndent indent) |
Methods invoked by print to print information about the object including superclasses. More... | |
Static Public Member Functions | |
static vtkTypeBool | IsTypeOf (const char *type) |
static vtkOctreePointLocatorNode * | SafeDownCast (vtkObjectBase *o) |
static vtkOctreePointLocatorNode * | New () |
Static Public Member Functions inherited from vtkObject | |
static vtkObject * | New () |
Create an object with Debug turned off, modified time initialized to zero, and reference counting on. More... | |
static void | BreakOnError () |
This method is called when vtkErrorMacro executes. More... | |
static void | SetGlobalWarningDisplay (int val) |
This is a global flag that controls whether any debug, warning or error messages are displayed. More... | |
static void | GlobalWarningDisplayOn () |
This is a global flag that controls whether any debug, warning or error messages are displayed. More... | |
static void | GlobalWarningDisplayOff () |
This is a global flag that controls whether any debug, warning or error messages are displayed. More... | |
static int | GetGlobalWarningDisplay () |
This is a global flag that controls whether any debug, warning or error messages are displayed. More... | |
Static Public Member Functions inherited from vtkObjectBase | |
static vtkTypeBool | IsTypeOf (const char *name) |
Return 1 if this class type is the same type of (or a subclass of) the named class. More... | |
static vtkObjectBase * | New () |
Create an object with Debug turned off, modified time initialized to zero, and reference counting on. More... | |
Protected Member Functions | |
virtual vtkObjectBase * | NewInstanceInternal () const |
vtkOctreePointLocatorNode () | |
~vtkOctreePointLocatorNode () override | |
Protected Member Functions inherited from vtkObject | |
vtkObject () | |
~vtkObject () override | |
void | RegisterInternal (vtkObjectBase *, vtkTypeBool check) override |
void | UnRegisterInternal (vtkObjectBase *, vtkTypeBool check) override |
void | InternalGrabFocus (vtkCommand *mouseEvents, vtkCommand *keypressEvents=nullptr) |
These methods allow a command to exclusively grab all events. More... | |
void | InternalReleaseFocus () |
These methods allow a command to exclusively grab all events. More... | |
Protected Member Functions inherited from vtkObjectBase | |
vtkObjectBase () | |
virtual | ~vtkObjectBase () |
virtual void | CollectRevisions (ostream &) |
virtual void | ReportReferences (vtkGarbageCollector *) |
vtkObjectBase (const vtkObjectBase &) | |
void | operator= (const vtkObjectBase &) |
Additional Inherited Members | |
Protected Attributes inherited from vtkObject | |
bool | Debug |
vtkTimeStamp | MTime |
vtkSubjectHelper * | SubjectHelper |
Protected Attributes inherited from vtkObjectBase | |
vtkAtomicInt32 | ReferenceCount |
vtkWeakPointerBase ** | WeakPointers |
Octree node that has 8 children each of equal size.
This class represents a single spatial region in a 3D axis octant partitioning. It is intended to work efficiently with the vtkOctreePointLocator and is not meant for general use. It is assumed the region bounds some set of points. The ordering of the children is (-x,-y,-z),(+x,-y,-z),(-x,+y,-z),(+x,+y,-z),(-x,-y,+z),(+x,-y,+z), (-x,+y,+z),(+x,+y,+z). The portion of the domain assigned to an octant is Min < x <= Max.
Definition at line 46 of file vtkOctreePointLocatorNode.h.
Definition at line 49 of file vtkOctreePointLocatorNode.h.
|
protected |
|
overrideprotected |
|
static |
|
virtual |
Return 1 if this class is the same type of (or a subclass of) the named class.
Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.
Reimplemented from vtkObjectBase.
|
static |
|
protectedvirtual |
vtkOctreePointLocatorNode* vtkOctreePointLocatorNode::NewInstance | ( | ) | const |
|
overridevirtual |
|
static |
|
inline |
Set/Get the number of points contained in this region.
Definition at line 58 of file vtkOctreePointLocatorNode.h.
|
virtual |
Set/Get the number of points contained in this region.
void vtkOctreePointLocatorNode::SetBounds | ( | double | xMin, |
double | xMax, | ||
double | yMin, | ||
double | yMax, | ||
double | zMin, | ||
double | zMax | ||
) |
Set/Get the bounds of the spatial region represented by this node.
Caller allocates storage for 6-vector in GetBounds.
|
inline |
Set/Get the bounds of the spatial region represented by this node.
Caller allocates storage for 6-vector in GetBounds.
Definition at line 72 of file vtkOctreePointLocatorNode.h.
void vtkOctreePointLocatorNode::GetBounds | ( | double * | b | ) | const |
Set/Get the bounds of the spatial region represented by this node.
Caller allocates storage for 6-vector in GetBounds.
void vtkOctreePointLocatorNode::SetDataBounds | ( | double | xMin, |
double | xMax, | ||
double | yMin, | ||
double | yMax, | ||
double | zMin, | ||
double | zMax | ||
) |
Set/Get the bounds of the points contained in this spatial region.
This may be smaller than the bounds of the region itself. Caller allocates storage for 6-vector in GetDataBounds.
void vtkOctreePointLocatorNode::GetDataBounds | ( | double * | b | ) | const |
Set/Get the bounds of the points contained in this spatial region.
This may be smaller than the bounds of the region itself. Caller allocates storage for 6-vector in GetDataBounds.
|
virtual |
Get a pointer to the 3 bound minima (xmin, ymin and zmin) or the 3 bound maxima (xmax, ymax, zmax).
Don't free this pointer.
|
virtual |
Get a pointer to the 3 bound minima (xmin, ymin and zmin) or the 3 bound maxima (xmax, ymax, zmax).
Don't free this pointer.
|
inline |
Set the xmin, ymin and zmin value of the bounds of this region.
Definition at line 103 of file vtkOctreePointLocatorNode.h.
|
inline |
Set the xmax, ymax and zmax value of the bounds of this region.
Definition at line 115 of file vtkOctreePointLocatorNode.h.
|
virtual |
Get a pointer to the 3 data bound minima (xmin, ymin and zmin) or the 3 data bound maxima (xmax, ymax, zmax).
Don't free this pointer.
|
virtual |
Get a pointer to the 3 data bound minima (xmin, ymin and zmin) or the 3 data bound maxima (xmax, ymax, zmax).
Don't free this pointer.
|
inline |
Set the xmin, ymin and zmin value of the bounds of this data within this region.
Definition at line 137 of file vtkOctreePointLocatorNode.h.
|
inline |
Set the xmax, ymax and zmax value of the bounds of this data within this region.
Definition at line 150 of file vtkOctreePointLocatorNode.h.
|
virtual |
Get the ID associated with the region described by this node.
If this is not a leaf node, this value should be -1.
|
virtual |
If this node is not a leaf node, there are leaf nodes below it whose regions represent a partitioning of this region.
The IDs of these leaf nodes form a contiguous set. Get the first of the first point's ID that is contained in this node.
void vtkOctreePointLocatorNode::CreateChildNodes | ( | ) |
Add the 8 children.
void vtkOctreePointLocatorNode::DeleteChildNodes | ( | ) |
Delete the 8 children.
vtkOctreePointLocatorNode* vtkOctreePointLocatorNode::GetChild | ( | int | i | ) |
Get a pointer to the ith child of this node.
int vtkOctreePointLocatorNode::IntersectsRegion | ( | vtkPlanesIntersection * | pi, |
int | useDataBounds | ||
) |
A vtkPlanesIntersection object represents a convex 3D region bounded by planes, and it is capable of computing intersections of boxes with itself.
Return 1 if this spatial region intersects the spatial region described by the vtkPlanesIntersection object. Use the possibly smaller bounds of the points within the region if useDataBounds is non-zero.
vtkTypeBool vtkOctreePointLocatorNode::ContainsPoint | ( | double | x, |
double | y, | ||
double | z, | ||
int | useDataBounds | ||
) |
Return 1 if this spatial region entirely contains the given point.
Use the possibly smaller bounds of the points within the region if useDataBounds is non-zero.
double vtkOctreePointLocatorNode::GetDistance2ToBoundary | ( | double | x, |
double | y, | ||
double | z, | ||
vtkOctreePointLocatorNode * | top, | ||
int | useDataBounds | ||
) |
Calculate the distance squared from any point to the boundary of this region.
Use the boundary of the points within the region if useDataBounds is non-zero.
double vtkOctreePointLocatorNode::GetDistance2ToBoundary | ( | double | x, |
double | y, | ||
double | z, | ||
double * | boundaryPt, | ||
vtkOctreePointLocatorNode * | top, | ||
int | useDataBounds | ||
) |
Calculate the distance squared from any point to the boundary of this region.
Use the boundary of the points within the region if useDataBounds is non-zero. Set boundaryPt to the point on the boundary.
double vtkOctreePointLocatorNode::GetDistance2ToInnerBoundary | ( | double | x, |
double | y, | ||
double | z, | ||
vtkOctreePointLocatorNode * | top | ||
) |
Calculate the distance from the specified point (which is required to be inside this spatial region) to an interior boundary.
An interior boundary is one that is not also an boundary of the entire space partitioned by the tree of vtkOctreePointLocatorNode's.
Return the id of the suboctant that a given point is in.
If CheckContainment is non-zero then it checks whether the point is in the actual bounding box of the suboctant, otherwise it only checks which octant the point is in that is created from the axis-aligned partitioning of the domain at this octant's center.
void vtkOctreePointLocatorNode::ComputeOctreeNodeInformation | ( | vtkOctreePointLocatorNode * | Parent, |
int & | NextLeafId, | ||
int & | NextMinId, | ||
float * | coordinates | ||
) |
Recursive function to compute ID, MinVal, MaxVal, and MinID.
Parent is used for MinVal and MaxVal in the case that no points are in the leaf node.