25#ifndef vtkHyperTreeGridGeometryEntry_h
26#define vtkHyperTreeGridGeometryEntry_h
30VTK_ABI_NAMESPACE_BEGIN
56 for (
unsigned int d = 0; d < 3; ++d)
58 this->Origin[d] = origin[d];
83 for (
unsigned int d = 0; d < 3; ++d)
85 this->Origin[d] = origin[d];
94 this->Index = entry->Index;
95 for (
unsigned int d = 0; d < 3; ++d)
97 this->Origin[d] = entry->Origin[d];
163 bool IsRoot()
const {
return (this->Index == 0); }
174 const double* sizeChild,
unsigned char ichild);
180 const double*
GetOrigin()
const {
return this->Origin; }
185 void GetBounds(
const double* sizeChild,
double bounds[6])
const
188 bounds[0] = this->Origin[0];
189 bounds[1] = this->Origin[0] + sizeChild[0];
190 bounds[2] = this->Origin[1];
191 bounds[3] = this->Origin[1] + sizeChild[1];
192 bounds[4] = this->Origin[2];
193 bounds[5] = this->Origin[2] + sizeChild[2];
199 void GetPoint(
const double* sizeChild,
double point[3])
const
202 point[0] = this->Origin[0] + sizeChild[0] / 2.;
203 point[1] = this->Origin[1] + sizeChild[1] / 2.;
204 point[2] = this->Origin[2] + sizeChild[2] / 2.;
GeometryEntry is a cache data for cursors requiring coordinates.
vtkHyperTreeGridGeometryEntry()
Constructor.
void GetBounds(const double *sizeChild, double bounds[6]) const
Getter for bounding box of the current cell.
void SubdivideLeaf(const vtkHyperTreeGrid *grid, vtkHyperTree *tree, unsigned int level)
Change the current cell's status: if leaf then becomes coarse and all its children are created,...
double * GetOrigin()
Getter for origin coordinates of the current cell.
void SetGlobalIndexStart(vtkHyperTree *tree, vtkIdType index)
Set the global index for the root cell of the HyperTree.
const double * GetOrigin() const
void Dump(ostream &os)
Dump information.
vtkHyperTreeGridGeometryEntry(vtkIdType index, const double *origin)
Constructor.
void PrintSelf(ostream &os, vtkIndent indent)
Display info about the entry.
vtkHyperTreeGridGeometryEntry & operator=(vtkHyperTreeGridGeometryEntry const &)=default
bool IsRoot() const
Is the cursor at tree root?
void SetGlobalIndexFromLocal(vtkHyperTree *tree, vtkIdType index)
Set the global index for the current cell of the HyperTree.
vtkIdType GetVertexId() const
Return the index of the current vertex in the tree.
bool IsLeaf(const vtkHyperTreeGrid *grid, const vtkHyperTree *tree, unsigned int level) const
Is the cursor pointing to a leaf?
~vtkHyperTreeGridGeometryEntry()=default
Destructor.
vtkHyperTreeGridGeometryEntry(vtkHyperTreeGridGeometryEntry const &)=default
void Initialize(vtkIdType index, const double *origin)
Initialize cursor from explicit required data.
bool IsMasked(const vtkHyperTreeGrid *grid, const vtkHyperTree *tree) const
Determine whether blanking mask is empty or not.
void ToChild(const vtkHyperTreeGrid *grid, const vtkHyperTree *tree, unsigned int level, const double *sizeChild, unsigned char ichild)
Move the cursor to child ‘child’ of the current vertex.
vtkHyperTree * Initialize(vtkHyperTreeGrid *grid, vtkIdType treeIndex, bool create=false)
Initialize cursor at root of given tree index in grid.
void Copy(const vtkHyperTreeGridGeometryEntry *entry)
Copy function.
vtkIdType GetGlobalNodeIndex(const vtkHyperTree *tree) const
Return the global index (relative to the grid) of the current vertex in the tree.
void SetMask(const vtkHyperTreeGrid *grid, const vtkHyperTree *tree, bool state)
Set the blanking mask is empty or not.
bool IsTerminalNode(const vtkHyperTreeGrid *grid, const vtkHyperTree *tree, unsigned int level) const
Is the cursor pointing to a coarse with all children leaves ?
void GetPoint(const double *sizeChild, double point[3]) const
Getter for center of the current cell.
A dataset containing a grid of vtkHyperTree instances arranged as a rectilinear grid.
A data object structured as a tree.
a simple class to control print indentation