///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2011-2012 Statoil ASA, Ceetron AS // // ResInsight is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // ResInsight is distributed in the hope that it will be useful, but WITHOUT ANY // WARRANTY; without even the implied warranty of MERCHANTABILITY or // FITNESS FOR A PARTICULAR PURPOSE. // // See the GNU General Public License at // for more details. // ///////////////////////////////////////////////////////////////////////////////// #pragma once #include "cvfBase.h" #include "cvfObject.h" #include "cvfVector3.h" #include "cvfBoundingBox.h" #include class RigActiveCellInfo : public cvf::Object { public: RigActiveCellInfo(); void setGlobalCellCount(size_t globalCellCount); bool isActive(size_t globalCellIndex) const; size_t cellResultIndex(size_t globalCellIndex) const; void setCellResultIndex(size_t globalCellIndex, size_t globalActiveCellIndex); void setGridCount(size_t gridCount); void setGridActiveCellCounts(size_t gridIndex, size_t activeCellCount); void gridActiveCellCounts(size_t gridIndex, size_t& activeCellCount); void computeDerivedData(); size_t globalActiveCellCount() const; void setIJKBoundingBox(const cvf::Vec3st& min, const cvf::Vec3st& max); void IJKBoundingBox(cvf::Vec3st& min, cvf::Vec3st& max) const; cvf::BoundingBox geometryBoundingBox() const; void setGeometryBoundingBox(cvf::BoundingBox bb); void clear(); private: class GridActiveCellCounts { public: size_t activeCellCount() const; void setActiveCellCount(size_t activeCellCount); private: size_t m_activeCellCount; }; private: std::vector m_perGridActiveCellInfo; std::vector m_cellIndexToResultIndex; size_t m_globalActiveCellCount; cvf::Vec3st m_activeCellPositionMin; cvf::Vec3st m_activeCellPositionMax; cvf::BoundingBox m_activeCellsBoundingBox; };