Moved Block from PolyVoxCore to PolyVoxImpl.
This commit is contained in:
		
							
								
								
									
										168
									
								
								library/PolyVoxCore/include/PolyVoxImpl/Block.inl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										168
									
								
								library/PolyVoxCore/include/PolyVoxImpl/Block.inl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,168 @@ | ||||
| #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 | ||||
|  | ||||
| #pragma region Headers | ||||
| #include "PolyVoxImpl/Utility.h" | ||||
| #include "Vector.h" | ||||
| #include "Volume.h" | ||||
|  | ||||
| #include <cassert> | ||||
| #include <cstring> //For memcpy | ||||
| #include <stdexcept> //for std::invalid_argument | ||||
| #pragma endregion | ||||
|  | ||||
| namespace PolyVox | ||||
| { | ||||
| 	#pragma region Constructors/Destructors | ||||
| 	template <typename VoxelType> | ||||
| 	Block<VoxelType>::Block(uint16_t uSideLength) | ||||
| 		:m_tData(0) | ||||
| 	{ | ||||
| 		//Debug mode validation | ||||
| 		assert(isPowerOf2(uSideLength)); | ||||
|  | ||||
| 		//Release mode validation | ||||
| 		if(!isPowerOf2(uSideLength)) | ||||
| 		{ | ||||
| 			throw std::invalid_argument("Block side length must be a power of two."); | ||||
| 		} | ||||
|  | ||||
| 		//Compute the side length		 | ||||
| 		m_uSideLength = uSideLength; | ||||
| 		m_uSideLengthPower = logBase2(uSideLength); | ||||
|  | ||||
| 		//If this fails an exception will be thrown. Memory is not    | ||||
| 		//allocated and there is nothing else in this class to clean up | ||||
| 		m_tData = new VoxelType[m_uSideLength * m_uSideLength * m_uSideLength]; | ||||
| 	} | ||||
|  | ||||
| 	template <typename VoxelType> | ||||
| 	Block<VoxelType>::Block(const Block<VoxelType>& rhs) | ||||
| 	{ | ||||
| 		*this = rhs; | ||||
| 	} | ||||
|  | ||||
| 	template <typename VoxelType> | ||||
| 	Block<VoxelType>::~Block() | ||||
| 	{ | ||||
| 		delete[] m_tData; | ||||
| 		m_tData = 0; | ||||
| 	} | ||||
| 	#pragma endregion | ||||
|  | ||||
| 	#pragma region Operators | ||||
| 	template <typename VoxelType> | ||||
| 	Block<VoxelType>& Block<VoxelType>::operator=(const Block<VoxelType>& rhs) | ||||
| 	{ | ||||
| 		if (this == &rhs) | ||||
| 		{ | ||||
| 			return *this; | ||||
| 		} | ||||
|  | ||||
| 		//If this fails an exception will be thrown. Memory is not    | ||||
| 		//allocated and there is nothing else in this class to clean up | ||||
| 		m_tData = new VoxelType[rhs.m_uSideLength * rhs.m_uSideLength * rhs.m_uSideLength]; | ||||
|  | ||||
| 		//Copy the data | ||||
| 		m_uSideLength = rhs.m_uSideLength; | ||||
| 		m_uSideLengthPower = rhs.m_uSideLengthPower;		 | ||||
| 		memcpy(m_tData, rhs.m_tData, m_uSideLength * m_uSideLength * m_uSideLength * sizeof(VoxelType)); | ||||
|  | ||||
| 		return *this; | ||||
| 	} | ||||
| 	#pragma endregion | ||||
|  | ||||
| 	#pragma region Getters | ||||
| 	template <typename VoxelType> | ||||
| 	uint16_t Block<VoxelType>::getSideLength(void) const | ||||
| 	{ | ||||
| 		return m_uSideLength; | ||||
| 	} | ||||
|  | ||||
| 	template <typename VoxelType> | ||||
| 	VoxelType Block<VoxelType>::getVoxelAt(uint16_t uXPos, uint16_t uYPos, uint16_t uZPos) const | ||||
| 	{ | ||||
| 		assert(uXPos < m_uSideLength); | ||||
| 		assert(uYPos < m_uSideLength); | ||||
| 		assert(uZPos < m_uSideLength); | ||||
|  | ||||
| 		return m_tData | ||||
| 			[ | ||||
| 				uXPos +  | ||||
| 				uYPos * m_uSideLength +  | ||||
| 				uZPos * m_uSideLength * m_uSideLength | ||||
| 			]; | ||||
| 	} | ||||
|  | ||||
| 	template <typename VoxelType> | ||||
| 	VoxelType Block<VoxelType>::getVoxelAt(const Vector3DUint16& v3dPos) const | ||||
| 	{ | ||||
| 		return getVoxelAt(v3dPos.getX(), v3dPos.getY(), v3dPos.getZ()); | ||||
| 	} | ||||
| 	#pragma endregion | ||||
|  | ||||
| 	#pragma region Setters | ||||
| 	template <typename VoxelType> | ||||
| 	void Block<VoxelType>::setVoxelAt(uint16_t uXPos, uint16_t uYPos, uint16_t uZPos, VoxelType tValue) | ||||
| 	{ | ||||
| 		assert(uXPos < m_uSideLength); | ||||
| 		assert(uYPos < m_uSideLength); | ||||
| 		assert(uZPos < m_uSideLength); | ||||
|  | ||||
| 		m_tData | ||||
| 		[ | ||||
| 			uXPos +  | ||||
| 			uYPos * m_uSideLength +  | ||||
| 			uZPos * m_uSideLength * m_uSideLength | ||||
| 		] = tValue; | ||||
| 	} | ||||
|  | ||||
| 	template <typename VoxelType> | ||||
| 	void Block<VoxelType>::setVoxelAt(const Vector3DUint16& v3dPos, VoxelType tValue) | ||||
| 	{ | ||||
| 		setVoxelAt(v3dPos.getX(), v3dPos.getY(), v3dPos.getZ(), tValue); | ||||
| 	} | ||||
| 	#pragma endregion | ||||
|  | ||||
| 	#pragma region Other | ||||
| 	template <typename VoxelType> | ||||
| 	void Block<VoxelType>::fill(VoxelType tValue) | ||||
| 	{ | ||||
| 		memset(m_tData, (int)tValue, m_uSideLength * m_uSideLength * m_uSideLength * sizeof(VoxelType)); | ||||
| 	} | ||||
|  | ||||
| 	template <typename VoxelType> | ||||
| 	bool Block<VoxelType>::isHomogeneous(void) | ||||
| 	{ | ||||
| 		const VoxelType tFirstVoxel = m_tData[0]; | ||||
| 		const uint32_t uNoOfVoxels = m_uSideLength * m_uSideLength * m_uSideLength; | ||||
|  | ||||
| 		for(uint32_t ct = 1; ct < uNoOfVoxels; ++ct) | ||||
| 		{ | ||||
| 			if(m_tData[ct] != tFirstVoxel) | ||||
| 			{ | ||||
| 				return false; | ||||
| 			} | ||||
| 		} | ||||
| 		return true; | ||||
| 	} | ||||
| 	#pragma endregion | ||||
| } | ||||
		Reference in New Issue
	
	Block a user