VTK
vtkDataObjectTreeIterator.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkDataObjectTreeIterator.h
5 
6  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7  All rights reserved.
8  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9 
10  This software is distributed WITHOUT ANY WARRANTY; without even
11  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12  PURPOSE. See the above copyright notice for more information.
13 
14 =========================================================================*/
23 #ifndef vtkDataObjectTreeIterator_h
24 #define vtkDataObjectTreeIterator_h
25 
26 #include "vtkCommonDataModelModule.h" // For export macro
28 #include "vtkSmartPointer.h" //to store data sets
29 
30 class vtkDataObjectTree;
33 class vtkDataObject;
34 class vtkInformation;
35 
36 class VTKCOMMONDATAMODEL_EXPORT vtkDataObjectTreeIterator : public vtkCompositeDataIterator
37 {
38 public:
41  void PrintSelf(ostream& os, vtkIndent indent) override;
42 
46  void GoToFirstItem() override;
47 
51  void GoToNextItem() override;
52 
59  int IsDoneWithTraversal() override;
60 
65 
73 
78  int HasCurrentMetaData() override;
79 
85  unsigned int GetCurrentFlatIndex() override;
86 
88 
98  vtkSetMacro(VisitOnlyLeaves, vtkTypeBool);
99  vtkGetMacro(VisitOnlyLeaves, vtkTypeBool);
100  vtkBooleanMacro(VisitOnlyLeaves, vtkTypeBool);
102 
104 
109  vtkSetMacro(TraverseSubTree, vtkTypeBool);
110  vtkGetMacro(TraverseSubTree, vtkTypeBool);
111  vtkBooleanMacro(TraverseSubTree, vtkTypeBool);
113 
114 protected:
116  ~vtkDataObjectTreeIterator() override;
117 
118  // Takes the current location to the next dataset. This traverses the tree in
119  // preorder fashion.
120  // If the current location is a composite dataset, next is its 1st child dataset.
121  // If the current is not a composite dataset, then next is the next dataset.
122  // This method gives no guarantees whether the current dataset will be
123  // non-null or leaf.
124  void NextInternal();
125 
129  vtkDataObjectTreeIndex GetCurrentIndex();
130 
131  // Needs access to GetCurrentIndex().
132  friend class vtkDataObjectTree;
133  friend class vtkMultiDataSetInternal;
134 
135  unsigned int CurrentFlatIndex;
136 
137 private:
139  void operator=(const vtkDataObjectTreeIterator&) = delete;
140 
141  class vtkInternals;
142  vtkInternals* Internals;
143  friend class vtkInternals;
144 
145  vtkTypeBool TraverseSubTree;
146  vtkTypeBool VisitOnlyLeaves;
147 
153 
154  // Cannot be called when this->IsDoneWithTraversal() return 1.
155  void UpdateLocation();
156 
157 };
158 
159 #endif
vtkDataObjectTree
provides implementation for most abstract methods in the superclass vtkCompositeDataSet
Definition: vtkDataObjectTree.h:46
vtkCompositeDataIterator::GoToFirstItem
virtual void GoToFirstItem()=0
Move the iterator to the beginning of the collection.
vtkObject::New
static vtkObject * New()
Create an object with Debug turned off, modified time initialized to zero, and reference counting on.
vtkCompositeDataIterator.h
vtkCompositeDataIterator::GetCurrentDataObject
virtual vtkDataObject * GetCurrentDataObject()=0
Returns the current item.
vtkCompositeDataIterator::IsDoneWithTraversal
virtual int IsDoneWithTraversal()=0
Test whether the iterator is finished with the traversal.
vtkCompositeDataIterator
superclass for composite data iterators
Definition: vtkCompositeDataIterator.h:35
vtkIndent
a simple class to control print indentation
Definition: vtkIndent.h:33
vtkSmartPointer.h
vtkInformation
Store vtkAlgorithm input/output information.
Definition: vtkInformation.h:80
vtkCompositeDataIterator::GetCurrentMetaData
virtual vtkInformation * GetCurrentMetaData()=0
Returns the meta-data associated with the current item.
vtkDataObjectTreeIterator
superclass for composite data iterators
Definition: vtkDataObjectTreeIterator.h:36
vtkCompositeDataIterator::GetCurrentFlatIndex
virtual unsigned int GetCurrentFlatIndex()=0
Flat index is an index to identify the data in a composite data structure.
vtkCompositeDataIterator::PrintSelf
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
vtkCompositeDataIterator::HasCurrentMetaData
virtual int HasCurrentMetaData()=0
Returns if the a meta-data information object is present for the current item.
vtkDataObjectTreeIndex
Definition: vtkDataObjectTreeInternals.h:56
vtkDataObject
general representation of visualization data
Definition: vtkDataObject.h:58
vtkDataObjectTreeIterator::CurrentFlatIndex
unsigned int CurrentFlatIndex
Definition: vtkDataObjectTreeIterator.h:135
vtkTypeBool
int vtkTypeBool
Definition: vtkABI.h:69
vtkDataObjectTreeInternals
Definition: vtkDataObjectTreeInternals.h:44
vtkCompositeDataIterator::GoToNextItem
virtual void GoToNextItem()=0
Move the iterator to the next item in the collection.