mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 14:26:40 +00:00 
			
		
		
		
	getTerrainHeightAt takes a worldspace. Doesn't change anything for now => Therrain is created with the default ESM3 worldspace, and is never changed.
		
			
				
	
	
		
			59 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef COMPONENTS_TERRAIN_TERRAINGRID_H
 | |
| #define COMPONENTS_TERRAIN_TERRAINGRID_H
 | |
| 
 | |
| #include <map>
 | |
| 
 | |
| #include <osg/Vec2f>
 | |
| 
 | |
| #include "world.hpp"
 | |
| 
 | |
| namespace osg
 | |
| {
 | |
|     class Group;
 | |
|     class Stats;
 | |
| }
 | |
| 
 | |
| namespace Resource
 | |
| {
 | |
|     class ResourceSystem;
 | |
| }
 | |
| 
 | |
| namespace Terrain
 | |
| {
 | |
|     class Storage;
 | |
| 
 | |
|     /// @brief Simple terrain implementation that loads cells in a grid, with no LOD. Only requested cells are loaded.
 | |
|     class TerrainGrid : public Terrain::World
 | |
|     {
 | |
|     public:
 | |
|         TerrainGrid(osg::Group* parent, osg::Group* compileRoot, Resource::ResourceSystem* resourceSystem,
 | |
|             Storage* storage, unsigned int nodeMask, ESM::RefId worldspace, unsigned int preCompileMask = ~0u,
 | |
|             unsigned int borderMask = 0);
 | |
|         TerrainGrid(osg::Group* parent, Storage* storage, ESM::RefId worldspace, unsigned int nodeMask = ~0u);
 | |
|         ~TerrainGrid();
 | |
| 
 | |
|         void cacheCell(View* view, int x, int y) override;
 | |
| 
 | |
|         /// @note Not thread safe.
 | |
|         void loadCell(int x, int y) override;
 | |
| 
 | |
|         /// @note Not thread safe.
 | |
|         void unloadCell(int x, int y) override;
 | |
| 
 | |
|         View* createView() override;
 | |
| 
 | |
|     protected:
 | |
|         bool isGridEmpty() const { return mGrid.empty(); }
 | |
| 
 | |
|     private:
 | |
|         osg::ref_ptr<osg::Node> buildTerrain(osg::Group* parent, float chunkSize, const osg::Vec2f& chunkCenter);
 | |
|         void updateWaterCulling();
 | |
| 
 | |
|         // split each ESM::Cell into mNumSplits*mNumSplits terrain chunks
 | |
|         unsigned int mNumSplits;
 | |
| 
 | |
|         CellBorder::CellGrid mGrid;
 | |
|     };
 | |
| }
 | |
| 
 | |
| #endif
 |