#include <vtkHyperOctreeCursor.h>
Objects that can traverse hyperoctree nodes. It is an abstract class. Cursors are created by the hyperoctree.
Definition at line 49 of file vtkHyperOctreeCursor.h.
Public Types | |
typedef vtkObject | Superclass |
Public Member Functions | |
virtual const char * | GetClassName () |
virtual int | IsA (const char *type) |
void | PrintSelf (ostream &os, vtkIndent indent) |
virtual int | GetLeafId ()=0 |
virtual int | CurrentIsLeaf ()=0 |
virtual int | CurrentIsRoot ()=0 |
virtual int | GetCurrentLevel ()=0 |
virtual int | GetChildIndex ()=0 |
virtual int | CurrentIsTerminalNode ()=0 |
virtual void | ToRoot ()=0 |
virtual void | ToParent ()=0 |
virtual void | ToChild (int child)=0 |
virtual void | ToSameNode (vtkHyperOctreeCursor *other)=0 |
virtual int | IsEqual (vtkHyperOctreeCursor *other)=0 |
virtual vtkHyperOctreeCursor * | Clone ()=0 |
virtual int | SameTree (vtkHyperOctreeCursor *other)=0 |
virtual int | GetIndex (int d)=0 |
virtual int | GetNumberOfChildren ()=0 |
virtual int | GetDimension ()=0 |
virtual int | Found ()=0 |
virtual void | MoveToNode (int *indices, int level)=0 |
Static Public Member Functions | |
static int | IsTypeOf (const char *type) |
static vtkHyperOctreeCursor * | SafeDownCast (vtkObject *o) |
Protected Member Functions | |
vtkHyperOctreeCursor () | |
virtual | ~vtkHyperOctreeCursor () |
vtkHyperOctreeCursor::vtkHyperOctreeCursor | ( | ) | [protected] |
virtual vtkHyperOctreeCursor::~vtkHyperOctreeCursor | ( | ) | [protected, virtual] |
virtual const char* vtkHyperOctreeCursor::GetClassName | ( | ) | [virtual] |
Reimplemented from vtkObject.
static int vtkHyperOctreeCursor::IsTypeOf | ( | const char * | name | ) | [static] |
Return 1 if this class type 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 vtkObject.
virtual int vtkHyperOctreeCursor::IsA | ( | const char * | name | ) | [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 vtkObject.
static vtkHyperOctreeCursor* vtkHyperOctreeCursor::SafeDownCast | ( | vtkObject * | o | ) | [static] |
Reimplemented from vtkObject.
void vtkHyperOctreeCursor::PrintSelf | ( | ostream & | os, | |
vtkIndent | indent | |||
) | [virtual] |
virtual int vtkHyperOctreeCursor::GetLeafId | ( | ) | [pure virtual] |
Return the index of the current leaf in the data arrays.
virtual int vtkHyperOctreeCursor::CurrentIsLeaf | ( | ) | [pure virtual] |
Is the node pointed by the cursor a leaf?
virtual int vtkHyperOctreeCursor::CurrentIsRoot | ( | ) | [pure virtual] |
Is the node pointed by the cursor the root?
virtual int vtkHyperOctreeCursor::GetCurrentLevel | ( | ) | [pure virtual] |
Return the level of the node pointed by the cursor.
virtual int vtkHyperOctreeCursor::GetChildIndex | ( | ) | [pure virtual] |
Return the child number of the current node relative to its parent.
virtual int vtkHyperOctreeCursor::CurrentIsTerminalNode | ( | ) | [pure virtual] |
virtual void vtkHyperOctreeCursor::ToRoot | ( | ) | [pure virtual] |
virtual void vtkHyperOctreeCursor::ToParent | ( | ) | [pure virtual] |
Move the cursor to the parent of the current node.
virtual void vtkHyperOctreeCursor::ToChild | ( | int | child | ) | [pure virtual] |
Move the cursor to child `child' of the current node.
valid_child: child>=0 && child<this->GetNumberOfChildren()
virtual void vtkHyperOctreeCursor::ToSameNode | ( | vtkHyperOctreeCursor * | other | ) | [pure virtual] |
Move the cursor to the same node pointed by `other'.
same_hyperoctree: this->SameTree(other);
virtual int vtkHyperOctreeCursor::IsEqual | ( | vtkHyperOctreeCursor * | other | ) | [pure virtual] |
Is `this' equal to `other'?
same_hyperoctree: this->SameTree(other);
virtual vtkHyperOctreeCursor* vtkHyperOctreeCursor::Clone | ( | ) | [pure virtual] |
Create a copy of `this'.
same_tree: result->SameTree(this)
virtual int vtkHyperOctreeCursor::SameTree | ( | vtkHyperOctreeCursor * | other | ) | [pure virtual] |
Are `this' and `other' pointing on the same hyperoctree?
virtual int vtkHyperOctreeCursor::GetIndex | ( | int | d | ) | [pure virtual] |
Return the index in dimension `d', as if the node was a cell of a uniform grid of 1<<GetCurrentLevel() cells in each dimension.
virtual int vtkHyperOctreeCursor::GetNumberOfChildren | ( | ) | [pure virtual] |
Return the number of children for each node of the tree.
virtual int vtkHyperOctreeCursor::GetDimension | ( | ) | [pure virtual] |
Return the dimension of the tree.
virtual void vtkHyperOctreeCursor::MoveToNode | ( | int * | indices, | |
int | level | |||
) | [pure virtual] |
Move to the node described by its indices in each dimension and at a given level. If there is actually a node or a leaf at this location, Found() returns true. Otherwise, Found() returns false and the cursor moves to the closest parent of the query. It can be the root in the worst case.
valid_size: sizeof(indices)==GetDimension()
valid_level: level>=0
virtual int vtkHyperOctreeCursor::Found | ( | ) | [pure virtual] |
Did the last call to MoveToNode succeed?