/*========================================================================= Program: Visualization Toolkit Module: vtkBridgeCellIteratorOne.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 vtkBridgeCellIteratorOne * @brief Iterate over one cell only of a dataset. * @sa * vtkBridgeCellIterator, vtkBridgeDataSet, vtkBridgeCellIteratorStrategy */ #ifndef vtkBridgeCellIteratorOne_h #define vtkBridgeCellIteratorOne_h #include "vtkBridgeCellIteratorStrategy.h" class vtkBridgeCell; class vtkBridgeDataSet; class vtkBridgeCell; class vtkIdList; class vtkPoints; class vtkCell; class VTKTESTINGGENERICBRIDGE_EXPORT vtkBridgeCellIteratorOne : public vtkBridgeCellIteratorStrategy { public: static vtkBridgeCellIteratorOne *New(); vtkTypeMacro(vtkBridgeCellIteratorOne, vtkBridgeCellIteratorStrategy); 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; /** * 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 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 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: vtkBridgeCellIteratorOne(); ~vtkBridgeCellIteratorOne() override; int cIsAtEnd; vtkBridgeDataSet *DataSet; // the structure on which the objet iterates. vtkIdType Id; // the id at current position. vtkBridgeCell *Cell; // cell at current position. vtkCell *InternalCell; private: vtkBridgeCellIteratorOne(const vtkBridgeCellIteratorOne&) = delete; void operator=(const vtkBridgeCellIteratorOne&) = delete; }; #endif