#pragma region License /****************************************************************************** This file is part of the PolyVox library Copyright (C) 2006 David Williams This program 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 2 of the License, or (at your option) any later version. This program 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 for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. ******************************************************************************/ #pragma endregion #ifndef __PolyVox_Volume_H__ #define __PolyVox_Volume_H__ #pragma region Headers #include "PolyVoxImpl/Block.h" #include "PolyVoxForwardDeclarations.h" #include "PolyVoxImpl/CPlusPlusZeroXSupport.h" #include #include #include #pragma endregion namespace PolyVox { template class Volume { //Make VolumeIterator a friend friend class VolumeIterator; public: Volume(uint16_t uSideLength, uint16_t uBlockSideLength = 64); //Volume(const Volume& rhs); ~Volume(); //Volume& operator=(const Volume& rhs); Region getEnclosingRegion(void) const; uint16_t getSideLength(void) const; VoxelType getVoxelAt(uint16_t uXPos, uint16_t uYPos, uint16_t uZPos) const; VoxelType getVoxelAt(const Vector3DUint16& v3dPos) const; void setVoxelAt(uint16_t uXPos, uint16_t uYPos, uint16_t uZPos, VoxelType tValue); void setVoxelAt(const Vector3DUint16& v3dPos, VoxelType tValue); void tidyUpMemory(uint32_t uNoOfBlocksToProcess = std::numeric_limits::max); bool isRegionHomogenous(const Region& region); private: POLYVOX_SHARED_PTR< BlockData > getHomogenousBlockData(VoxelType tHomogenousValue) const; std::vector< Block > m_pBlocks; std::vector m_vecBlockIsPotentiallyHomogenous; //Note: We were once storing weak_ptr's in this map, so that the blocks would be deleted once they //were not being referenced by anyone else. However, this made it difficult to know when a block was //shared. A call to shared_ptr::unique() from within setVoxel was not sufficient as weak_ptr's did //not contribute to the reference count. Instead we store shared_ptr's here, and check if they //are used by anyone else (i.e are non-unique) when we tidy the volume. static std::map > > m_pHomogenousBlockData; uint32_t m_uNoOfBlocksInVolume; uint16_t m_uSideLengthInBlocks; uint8_t m_uSideLengthPower; uint16_t m_uSideLength; uint8_t m_uBlockSideLengthPower; uint16_t m_uBlockSideLength; uint32_t m_uCurrentBlockForTidying; }; //Required for the static member template std::map > > Volume::m_pHomogenousBlockData; //Some handy typedefs typedef Volume FloatVolume; typedef Volume UInt8Volume; typedef Volume UInt16Volume; } #include "Volume.inl" #endif