/*========================================================================= Program: Visualization Toolkit Module: vtkBridgeCellIterator.h Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen All rights reserved. See Copyright.txt or http://www.kitware.com/Copyright.htm for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the above copyright notice for more information. =========================================================================*/ /** * @class vtkBridgeCellIterator * @brief Implementation of vtkGenericCellIterator. * It is just an example that show how to implement the Generic API. It is also * used for testing and evaluating the Generic framework. * @sa * vtkGenericCellIterator, vtkBridgeDataSet */ #ifndef vtkBridgeCellIterator_h #define vtkBridgeCellIterator_h #include "vtkBridgeExport.h" //for module export macro #include "vtkGenericCellIterator.h" class vtkBridgeCell; class vtkBridgeDataSet; class vtkBridgeCell; class vtkIdList; class vtkBridgeDataSet; class vtkPoints; class vtkBridgeCellIteratorStrategy; class vtkBridgeCellIteratorOnDataSet; class vtkBridgeCellIteratorOne; class vtkBridgeCellIteratorOnCellBoundaries; class vtkBridgeCellIteratorOnCellList; class VTKTESTINGGENERICBRIDGE_EXPORT vtkBridgeCellIterator : public vtkGenericCellIterator { public: static vtkBridgeCellIterator *New(); vtkTypeMacro(vtkBridgeCellIterator,vtkGenericCellIterator); void PrintSelf(ostream& os, vtkIndent indent) override; /** * Move iterator to first position if any (loop initialization). */ void Begin() override; /** * Is there no cell at iterator position? (exit condition). */ int IsAtEnd() override; /** * Create an empty cell. * \post result_exists: result!=0 */ vtkGenericAdaptorCell *NewCell() override; /** * Cell at current position * \pre not_at_end: !IsAtEnd() * \pre c_exists: c!=0 * THREAD SAFE */ void GetCell(vtkGenericAdaptorCell *c) override; /** * Cell at current position. * NOT THREAD SAFE * \pre not_at_end: !IsAtEnd() * \post result_exits: result!=0 */ vtkGenericAdaptorCell *GetCell() override; /** * Move iterator to next position. (loop progression). * \pre not_at_end: !IsAtEnd() */ void Next() override; /** * Used internally by vtkBridgeDataSet. * Iterate over cells of `ds' of some dimension `dim'. * \pre ds_exists: ds!=0 * \pre valid_dim_range: (dim>=-1) && (dim<=3) */ void InitWithDataSet(vtkBridgeDataSet *ds, int dim); /** * Used internally by vtkBridgeDataSet. * Iterate over boundary cells of `ds' of some dimension `dim'. * \pre ds_exists: ds!=0 * \pre valid_dim_range: (dim>=-1) && (dim<=3) */ void InitWithDataSetBoundaries(vtkBridgeDataSet *ds, int dim, int exterior_only); /** * Used internally by vtkBridgeDataSet. * Iterate on one cell `id' of `ds'. * \pre ds_exists: ds!=0 * \pre valid_id: (id>=0)&&(id<=ds->GetNumberOfCells()) */ void InitWithOneCell(vtkBridgeDataSet *ds, vtkIdType cellid); /** * Used internally by vtkBridgeCell. * Iterate on one cell `c'. * \pre c_exists: c!=0 */ void InitWithOneCell(vtkBridgeCell *c); /** * Used internally by vtkBridgeCell. * Iterate on boundary cells of a cell. * \pre cell_exists: cell!=0 * \pre valid_dim_range: (dim==-1) || ((dim>=0)&&(dimGetDimension())) */ void InitWithCellBoundaries(vtkBridgeCell *cell, int dim); /** * Used internally by vtkBridgeCell. * Iterate on neighbors defined by `cells' over the dataset `ds'. * \pre cells_exist: cells!=0 * \pre ds_exists: ds!=0 */ void InitWithCells(vtkIdList *cells, vtkBridgeDataSet *ds); /** * Used internally by vtkBridgeCell. * Iterate on a boundary cell (defined by its points `pts' with coordinates * `coords', dimension `dim' and unique id `cellid') of a cell. * \pre coords_exist: coords!=0 * \pre pts_exist: pts!=0 * \pre valid_dim: dim>=0 && dim<=2 * \pre valid_points: pts->GetNumberOfIds()>dim */ void InitWithPoints(vtkPoints *coords, vtkIdList *pts, int dim, vtkIdType cellid); protected: vtkBridgeCellIterator(); ~vtkBridgeCellIterator() override; vtkBridgeCellIteratorStrategy *CurrentIterator; vtkBridgeCellIteratorOnDataSet *IteratorOnDataSet; vtkBridgeCellIteratorOne *IteratorOneCell; vtkBridgeCellIteratorOnCellBoundaries * IteratorOnCellBoundaries; vtkBridgeCellIteratorOnCellList *IteratorOnCellList; vtkBridgeDataSet *DataSet; // the structure on which the objet iterates. vtkIdType Id; // the id at current position. int OneCell; // Is in one cell mode? vtkIdType Size; // size of the structure. vtkBridgeCell *Cell; // cell at current position. private: vtkBridgeCellIterator(const vtkBridgeCellIterator&) = delete; void operator=(const vtkBridgeCellIterator&) = delete; }; #endif