|
octomap
1.9.7
|
Iterator over the complete tree (inner nodes and leafs). More...
Inheritance diagram for tree_iterator:
Collaboration diagram for tree_iterator:Public Member Functions | |
| point3d | getCoordinate () const |
| return the center coordinate of the current node More... | |
| unsigned | getDepth () const |
| return depth of the current node More... | |
| OcTreeKey | getIndexKey () const |
| const OcTreeKey & | getKey () const |
| double | getSize () const |
| double | getX () const |
| double | getY () const |
| double | getZ () const |
| bool | isLeaf () const |
| bool | operator!= (const iterator_base &other) const |
| Comparison between iterators. First compares the tree, then stack size and top element of stack. More... | |
| NodeType & | operator* () |
| Return the current node in the octree which the iterator is referring to. More... | |
| const NodeType & | operator* () const |
| Return the current node in the octree which the iterator is referring to. More... | |
| tree_iterator & | operator++ () |
| Prefix increment operator to advance the iterator. More... | |
| tree_iterator | operator++ (int) |
| postfix increment operator of iterator (it++) More... | |
| NodeType * | operator-> () |
| Ptr operator will return the current node in the octree which the iterator is referring to. More... | |
| NodeType const * | operator-> () const |
| Ptr operator will return the current node in the octree which the iterator is referring to. More... | |
| bool | operator== (const iterator_base &other) const |
| Comparison between iterators. First compares the tree, then stack size and top element of stack. More... | |
| tree_iterator () | |
| tree_iterator (OcTreeBaseImpl< NodeType, INTERFACE > const *ptree, uint8_t depth=0) | |
| Constructor of the iterator. More... | |
Protected Member Functions | |
| void | singleIncrement () |
| One step of depth-first tree traversal. How this is used depends on the actual iterator. More... | |
Protected Attributes | |
| uint8_t | maxDepth |
| Maximum depth for depth-limited queries. More... | |
| std::stack< StackElement, std::vector< StackElement > > | stack |
| Internal recursion stack. Apparently a stack of vector works fastest here. More... | |
| OcTreeBaseImpl< NodeType, INTERFACE > const * | tree |
| Octree this iterator is working on. More... | |
Iterator over the complete tree (inner nodes and leafs).
See below for example usage. Note that the non-trivial call to tree->end_tree() should be done only once for efficiency!
|
inline |
|
inline |
Constructor of the iterator.
| ptree | OcTreeBaseImpl on which the iterator is used on |
| depth | Maximum depth to traverse the tree. 0 (default): unlimited |
|
inlineinherited |
return the center coordinate of the current node
References iterator_base::stack, and iterator_base::tree.
|
inlineinherited |
return depth of the current node
References iterator_base::stack.
|
inlineinherited |
References octomap::computeIndexKey(), iterator_base::stack, and iterator_base::tree.
|
inlineinherited |
References iterator_base::stack.
|
inlineinherited |
References iterator_base::stack, and iterator_base::tree.
|
inlineinherited |
References iterator_base::stack, and iterator_base::tree.
|
inlineinherited |
References iterator_base::stack, and iterator_base::tree.
|
inlineinherited |
References iterator_base::stack, and iterator_base::tree.
|
inline |
References iterator_base::tree.
|
inlineinherited |
Comparison between iterators. First compares the tree, then stack size and top element of stack.
References iterator_base::stack, and iterator_base::tree.
|
inlineinherited |
Return the current node in the octree which the iterator is referring to.
References iterator_base::stack.
|
inlineinherited |
Return the current node in the octree which the iterator is referring to.
References iterator_base::stack.
|
inline |
Prefix increment operator to advance the iterator.
References iterator_base::singleIncrement(), iterator_base::stack, and iterator_base::tree.
|
inline |
postfix increment operator of iterator (it++)
|
inlineinherited |
Ptr operator will return the current node in the octree which the iterator is referring to.
References iterator_base::stack.
|
inlineinherited |
Ptr operator will return the current node in the octree which the iterator is referring to.
References iterator_base::stack.
|
inlineinherited |
Comparison between iterators. First compares the tree, then stack size and top element of stack.
References iterator_base::stack, and iterator_base::tree.
|
inlineprotectedinherited |
One step of depth-first tree traversal. How this is used depends on the actual iterator.
References octomap::computeChildKey(), iterator_base::StackElement::depth, iterator_base::StackElement::key, iterator_base::maxDepth, iterator_base::StackElement::node, iterator_base::stack, and iterator_base::tree.
Referenced by operator++(), and leaf_iterator::operator++().
|
protectedinherited |
Maximum depth for depth-limited queries.
Referenced by iterator_base::iterator_base(), leaf_bbx_iterator::leaf_bbx_iterator(), iterator_base::operator=(), and iterator_base::singleIncrement().
|
protectedinherited |
Internal recursion stack. Apparently a stack of vector works fastest here.
Referenced by iterator_base::getCoordinate(), iterator_base::getDepth(), iterator_base::getIndexKey(), iterator_base::getKey(), iterator_base::getSize(), iterator_base::getX(), iterator_base::getY(), iterator_base::getZ(), iterator_base::iterator_base(), leaf_bbx_iterator::leaf_bbx_iterator(), leaf_iterator::leaf_iterator(), iterator_base::operator!=(), iterator_base::operator*(), operator++(), leaf_iterator::operator++(), leaf_bbx_iterator::operator++(), iterator_base::operator->(), iterator_base::operator=(), iterator_base::operator==(), iterator_base::singleIncrement(), and leaf_bbx_iterator::singleIncrement().
|
protectedinherited |
Octree this iterator is working on.
Referenced by iterator_base::getCoordinate(), iterator_base::getIndexKey(), iterator_base::getSize(), iterator_base::getX(), iterator_base::getY(), iterator_base::getZ(), isLeaf(), iterator_base::iterator_base(), leaf_bbx_iterator::leaf_bbx_iterator(), iterator_base::operator!=(), operator++(), leaf_iterator::operator++(), leaf_bbx_iterator::operator++(), iterator_base::operator=(), iterator_base::operator==(), iterator_base::singleIncrement(), and leaf_bbx_iterator::singleIncrement().