From 35d53acc65d66779fed914e626e3e63e4c15f938 Mon Sep 17 00:00:00 2001 From: scrawl Date: Mon, 6 Mar 2017 20:41:02 +0100 Subject: [PATCH] Factor out terrain chunk loading/caching into a new resource manager --- apps/opencs/view/render/cell.hpp | 1 + apps/openmw/mwrender/renderingmanager.cpp | 2 - apps/openmw/mwworld/cellpreloader.cpp | 8 +- components/CMakeLists.txt | 2 +- components/esmterrain/storage.cpp | 5 + components/esmterrain/storage.hpp | 2 + components/resource/scenemanager.cpp | 5 + components/resource/scenemanager.hpp | 2 + components/resource/stats.cpp | 2 +- components/terrain/chunkmanager.cpp | 180 +++++++++++++++++++ components/terrain/chunkmanager.hpp | 59 +++++++ components/terrain/storage.hpp | 2 + components/terrain/terraingrid.cpp | 202 ++-------------------- components/terrain/terraingrid.hpp | 13 +- components/terrain/world.cpp | 6 +- components/terrain/world.hpp | 9 +- 16 files changed, 285 insertions(+), 215 deletions(-) create mode 100644 components/terrain/chunkmanager.cpp create mode 100644 components/terrain/chunkmanager.hpp diff --git a/apps/opencs/view/render/cell.hpp b/apps/opencs/view/render/cell.hpp index 8f68e9f53..c89c1517f 100644 --- a/apps/opencs/view/render/cell.hpp +++ b/apps/opencs/view/render/cell.hpp @@ -4,6 +4,7 @@ #include #include #include +#include #include diff --git a/apps/openmw/mwrender/renderingmanager.cpp b/apps/openmw/mwrender/renderingmanager.cpp index 886673caf..090eddd0d 100644 --- a/apps/openmw/mwrender/renderingmanager.cpp +++ b/apps/openmw/mwrender/renderingmanager.cpp @@ -914,8 +914,6 @@ namespace MWRender if (stats->collectStats("resource")) { stats->setAttribute(frameNumber, "UnrefQueue", mUnrefQueue->getNumItems()); - - mTerrain->reportStats(frameNumber, stats); } } diff --git a/apps/openmw/mwworld/cellpreloader.cpp b/apps/openmw/mwworld/cellpreloader.cpp index db3ec5018..e45cf55bc 100644 --- a/apps/openmw/mwworld/cellpreloader.cpp +++ b/apps/openmw/mwworld/cellpreloader.cpp @@ -168,24 +168,20 @@ namespace MWWorld class UpdateCacheItem : public SceneUtil::WorkItem { public: - UpdateCacheItem(Resource::ResourceSystem* resourceSystem, Terrain::World* terrain, double referenceTime) + UpdateCacheItem(Resource::ResourceSystem* resourceSystem, double referenceTime) : mReferenceTime(referenceTime) , mResourceSystem(resourceSystem) - , mTerrain(terrain) { } virtual void doWork() { mResourceSystem->updateCache(mReferenceTime); - - mTerrain->updateCache(mReferenceTime); } private: double mReferenceTime; Resource::ResourceSystem* mResourceSystem; - Terrain::World* mTerrain; }; CellPreloader::CellPreloader(Resource::ResourceSystem* resourceSystem, Resource::BulletShapeManager* bulletShapeManager, Terrain::World* terrain, MWRender::LandManager* landManager) @@ -313,7 +309,7 @@ namespace MWWorld if (timestamp - mLastResourceCacheUpdate > 1.0) { // the resource cache is cleared from the worker thread so that we're not holding up the main thread with delete operations - mWorkQueue->addWorkItem(new UpdateCacheItem(mResourceSystem, mTerrain, timestamp), true); + mWorkQueue->addWorkItem(new UpdateCacheItem(mResourceSystem, timestamp), true); mLastResourceCacheUpdate = timestamp; } } diff --git a/components/CMakeLists.txt b/components/CMakeLists.txt index c1b329942..37c19f527 100644 --- a/components/CMakeLists.txt +++ b/components/CMakeLists.txt @@ -114,7 +114,7 @@ add_component_dir (translation ) add_component_dir (terrain - storage world buffercache defs terraingrid material terraindrawable texturemanager + storage world buffercache defs terraingrid material terraindrawable texturemanager chunkmanager ) add_component_dir (loadinglistener diff --git a/components/esmterrain/storage.cpp b/components/esmterrain/storage.cpp index e48c8aeb2..5d1591e79 100644 --- a/components/esmterrain/storage.cpp +++ b/components/esmterrain/storage.cpp @@ -612,4 +612,9 @@ namespace ESMTerrain return ESM::Land::LAND_SIZE; } + int Storage::getBlendmapScale(float chunkSize) + { + return ESM::Land::LAND_TEXTURE_SIZE*chunkSize; + } + } diff --git a/components/esmterrain/storage.hpp b/components/esmterrain/storage.hpp index 9204d4059..7502f44cd 100644 --- a/components/esmterrain/storage.hpp +++ b/components/esmterrain/storage.hpp @@ -99,6 +99,8 @@ namespace ESMTerrain /// Get the number of vertices on one side for each cell. Should be (power of two)+1 virtual int getCellVertices(); + virtual int getBlendmapScale(float chunkSize); + private: const VFS::Manager* mVFS; diff --git a/components/resource/scenemanager.cpp b/components/resource/scenemanager.cpp index fc31b00a0..da8ba180e 100644 --- a/components/resource/scenemanager.cpp +++ b/components/resource/scenemanager.cpp @@ -621,6 +621,11 @@ namespace Resource mIncrementalCompileOperation = ico; } + osgUtil::IncrementalCompileOperation *SceneManager::getIncrementalCompileOperation() + { + return mIncrementalCompileOperation.get(); + } + Resource::ImageManager* SceneManager::getImageManager() { return mImageManager; diff --git a/components/resource/scenemanager.hpp b/components/resource/scenemanager.hpp index fdd1d6583..3ed7d1bd3 100644 --- a/components/resource/scenemanager.hpp +++ b/components/resource/scenemanager.hpp @@ -121,6 +121,8 @@ namespace Resource /// Set up an IncrementalCompileOperation for background compiling of loaded scenes. void setIncrementalCompileOperation(osgUtil::IncrementalCompileOperation* ico); + osgUtil::IncrementalCompileOperation* getIncrementalCompileOperation(); + Resource::ImageManager* getImageManager(); /// @param mask The node mask to apply to loaded particle system nodes. diff --git a/components/resource/stats.cpp b/components/resource/stats.cpp index 3cc2d3b01..e2a91749e 100644 --- a/components/resource/stats.cpp +++ b/components/resource/stats.cpp @@ -259,7 +259,7 @@ void StatsHandler::setUpScene(osgViewer::ViewerBase *viewer) _resourceStatsChildNum = _switch->getNumChildren(); _switch->addChild(group, false); - const char* statNames[] = {"Compiling", "WorkQueue", "WorkThread", "", "Texture", "StateSet", "Node", "Node Instance", "Shape", "Shape Instance", "Image", "Nif", "Keyframe", "Terrain Cell", "Terrain Texture", "Land", "", "UnrefQueue"}; + const char* statNames[] = {"Compiling", "WorkQueue", "WorkThread", "", "Texture", "StateSet", "Node", "Node Instance", "Shape", "Shape Instance", "Image", "Nif", "Keyframe", "Terrain Chunk", "Terrain Texture", "Land", "", "UnrefQueue"}; int numLines = sizeof(statNames) / sizeof(statNames[0]); diff --git a/components/terrain/chunkmanager.cpp b/components/terrain/chunkmanager.cpp new file mode 100644 index 000000000..96bea517b --- /dev/null +++ b/components/terrain/chunkmanager.cpp @@ -0,0 +1,180 @@ +#include "chunkmanager.hpp" + +#include + +#include + +#include + +#include +#include + +#include + +#include "terraindrawable.hpp" +#include "material.hpp" +#include "storage.hpp" +#include "texturemanager.hpp" + +namespace +{ + class StaticBoundingBoxCallback : public osg::Drawable::ComputeBoundingBoxCallback + { + public: + StaticBoundingBoxCallback(const osg::BoundingBox& bounds) + : mBoundingBox(bounds) + { + } + + virtual osg::BoundingBox computeBound(const osg::Drawable&) const + { + return mBoundingBox; + } + + private: + osg::BoundingBox mBoundingBox; + }; +} + +namespace Terrain +{ + +ChunkManager::ChunkManager(Storage *storage, Resource::SceneManager *sceneMgr, TextureManager* textureManager) + : ResourceManager(NULL) + , mStorage(storage) + , mSceneManager(sceneMgr) + , mTextureManager(textureManager) + , mShaderManager(NULL) +{ + +} + +osg::ref_ptr ChunkManager::getChunk(float size, const osg::Vec2f ¢er) +{ + std::ostringstream stream; + stream << size << " " << center.x() << " " << center.y(); + std::string id = stream.str(); + + osg::ref_ptr obj = mCache->getRefFromObjectCache(id); + if (obj) + return obj->asNode(); + else + { + osg::ref_ptr node = createChunk(size, center); + mCache->addEntryToObjectCache(id, node.get()); + return node; + } +} + +void ChunkManager::setShaderManager(Shader::ShaderManager *shaderManager) +{ + mShaderManager = shaderManager; +} + +void ChunkManager::reportStats(unsigned int frameNumber, osg::Stats *stats) +{ + stats->setAttribute(frameNumber, "Terrain Chunk", mCache->getCacheSize()); +} + +osg::ref_ptr ChunkManager::createChunk(float chunkSize, const osg::Vec2f &chunkCenter) +{ + float minH, maxH; + if (!mStorage->getMinMaxHeights(chunkSize, chunkCenter, minH, maxH)) + return NULL; // no terrain defined + + osg::Vec2f worldCenter = chunkCenter*mStorage->getCellWorldSize(); + osg::ref_ptr transform (new SceneUtil::PositionAttitudeTransform); + transform->setPosition(osg::Vec3f(worldCenter.x(), worldCenter.y(), 0.f)); + + osg::ref_ptr positions (new osg::Vec3Array); + osg::ref_ptr normals (new osg::Vec3Array); + osg::ref_ptr colors (new osg::Vec4Array); + + osg::ref_ptr vbo (new osg::VertexBufferObject); + positions->setVertexBufferObject(vbo); + normals->setVertexBufferObject(vbo); + colors->setVertexBufferObject(vbo); + + unsigned int lod = 0; + + mStorage->fillVertexBuffers(lod, chunkSize, chunkCenter, positions, normals, colors); + + osg::ref_ptr geometry (new TerrainDrawable); + geometry->setVertexArray(positions); + geometry->setNormalArray(normals, osg::Array::BIND_PER_VERTEX); + geometry->setColorArray(colors, osg::Array::BIND_PER_VERTEX); + geometry->setUseDisplayList(false); + geometry->setUseVertexBufferObjects(true); + + unsigned int numVerts = (mStorage->getCellVertices()-1) * chunkSize / (1 << lod) + 1; + + geometry->addPrimitiveSet(mBufferCache.getIndexBuffer(numVerts, 0)); + + + // we already know the bounding box, so no need to let OSG compute it. + osg::Vec3f min(-0.5f*mStorage->getCellWorldSize()*chunkSize, + -0.5f*mStorage->getCellWorldSize()*chunkSize, + minH); + osg::Vec3f max (0.5f*mStorage->getCellWorldSize()*chunkSize, + 0.5f*mStorage->getCellWorldSize()*chunkSize, + maxH); + osg::BoundingBox bounds(min, max); + geometry->setComputeBoundingBoxCallback(new StaticBoundingBoxCallback(bounds)); + + std::vector layerList; + std::vector > blendmaps; + mStorage->getBlendmaps(chunkSize, chunkCenter, false, blendmaps, layerList); + + bool useShaders = mSceneManager->getForceShaders(); + if (!mSceneManager->getClampLighting()) + useShaders = true; // always use shaders when lighting is unclamped, this is to avoid lighting seams between a terrain chunk with normal maps and one without normal maps + std::vector layers; + { + for (std::vector::const_iterator it = layerList.begin(); it != layerList.end(); ++it) + { + TextureLayer textureLayer; + textureLayer.mParallax = it->mParallax; + textureLayer.mSpecular = it->mSpecular; + + textureLayer.mDiffuseMap = mTextureManager->getTexture(it->mDiffuseMap); + + if (!it->mNormalMap.empty()) + textureLayer.mNormalMap = mTextureManager->getTexture(it->mNormalMap); + + if (it->requiresShaders()) + useShaders = true; + + layers.push_back(textureLayer); + } + } + + std::vector > blendmapTextures; + for (std::vector >::const_iterator it = blendmaps.begin(); it != blendmaps.end(); ++it) + { + osg::ref_ptr texture (new osg::Texture2D); + texture->setImage(*it); + texture->setWrap(osg::Texture::WRAP_S, osg::Texture::CLAMP_TO_EDGE); + texture->setWrap(osg::Texture::WRAP_T, osg::Texture::CLAMP_TO_EDGE); + texture->setResizeNonPowerOfTwoHint(false); + blendmapTextures.push_back(texture); + } + + // use texture coordinates for both texture units, the layer texture and blend texture + for (unsigned int i=0; i<2; ++i) + geometry->setTexCoordArray(i, mBufferCache.getUVBuffer(numVerts)); + + float blendmapScale = mStorage->getBlendmapScale(chunkSize); + + geometry->setPasses(createPasses(mShaderManager ? useShaders : false, mSceneManager->getForcePerPixelLighting(), + mSceneManager->getClampLighting(), mShaderManager, layers, blendmapTextures, blendmapScale, blendmapScale)); + + transform->addChild(geometry); + + if (mSceneManager->getIncrementalCompileOperation()) + { + mSceneManager->getIncrementalCompileOperation()->add(geometry); + } + return transform; +} + +} diff --git a/components/terrain/chunkmanager.hpp b/components/terrain/chunkmanager.hpp new file mode 100644 index 000000000..4bb4c5432 --- /dev/null +++ b/components/terrain/chunkmanager.hpp @@ -0,0 +1,59 @@ +#ifndef OPENMW_COMPONENTS_TERRAIN_CHUNKMANAGER_H +#define OPENMW_COMPONENTS_TERRAIN_CHUNKMANAGER_H + +#include + +#include "buffercache.hpp" + +namespace osg +{ + class Geometry; +} + +namespace SceneUtil +{ + class PositionAttitudeTransform; +} + +namespace Resource +{ + class SceneManager; +} + +namespace Shader +{ + class ShaderManager; +} + +namespace Terrain +{ + + class TextureManager; + class Storage; + + /// @brief Handles loading and caching of terrain chunks + class ChunkManager : public Resource::ResourceManager + { + public: + ChunkManager(Storage* storage, Resource::SceneManager* sceneMgr, TextureManager* textureManager); + + osg::ref_ptr getChunk(float size, const osg::Vec2f& center); + + // Optional + void setShaderManager(Shader::ShaderManager* shaderManager); + + virtual void reportStats(unsigned int frameNumber, osg::Stats* stats); + + private: + osg::ref_ptr createChunk(float size, const osg::Vec2f& center); + + Terrain::Storage* mStorage; + Resource::SceneManager* mSceneManager; + TextureManager* mTextureManager; + Shader::ShaderManager* mShaderManager; + BufferCache mBufferCache; + }; + +} + +#endif diff --git a/components/terrain/storage.hpp b/components/terrain/storage.hpp index bd5706b25..efe8fa037 100644 --- a/components/terrain/storage.hpp +++ b/components/terrain/storage.hpp @@ -78,6 +78,8 @@ namespace Terrain /// Get the number of vertices on one side for each cell. Should be (power of two)+1 virtual int getCellVertices() = 0; + + virtual int getBlendmapScale(float chunkSize) = 0; }; } diff --git a/components/terrain/terraingrid.cpp b/components/terrain/terraingrid.cpp index 7a8307043..fa7b93684 100644 --- a/components/terrain/terraingrid.cpp +++ b/components/terrain/terraingrid.cpp @@ -3,47 +3,12 @@ #include #include -#include +#include -#include - -#include - -#include -#include -#include - -#include -#include #include -#include - - -#include "material.hpp" -#include "storage.hpp" -#include "terraindrawable.hpp" #include "texturemanager.hpp" - -namespace -{ - class StaticBoundingBoxCallback : public osg::Drawable::ComputeBoundingBoxCallback - { - public: - StaticBoundingBoxCallback(const osg::BoundingBox& bounds) - : mBoundingBox(bounds) - { - } - - virtual osg::BoundingBox computeBound(const osg::Drawable&) const - { - return mBoundingBox; - } - - private: - osg::BoundingBox mBoundingBox; - }; -} +#include "chunkmanager.hpp" namespace Terrain { @@ -57,6 +22,8 @@ TerrainGrid::TerrainGrid(osg::Group* parent, Resource::ResourceSystem* resourceS osg::ref_ptr material (new osg::Material); material->setColorMode(osg::Material::AMBIENT_AND_DIFFUSE); mTerrainRoot->getOrCreateStateSet()->setAttributeAndModes(material, osg::StateAttribute::ON); + + mChunkManager->setShaderManager(mShaderManager); } TerrainGrid::~TerrainGrid() @@ -69,17 +36,8 @@ TerrainGrid::~TerrainGrid() osg::ref_ptr TerrainGrid::cacheCell(int x, int y) { - { - OpenThreads::ScopedLock lock(mGridCacheMutex); - Grid::iterator found = mGridCache.find(std::make_pair(x,y)); - if (found != mGridCache.end()) - return found->second; - } - osg::ref_ptr node = buildTerrain(NULL, 1.f, osg::Vec2f(x+0.5, y+0.5)); - - OpenThreads::ScopedLock lock(mGridCacheMutex); - mGridCache.insert(std::make_pair(std::make_pair(x,y), node)); - return node; + osg::Vec2f center(x+0.5f, y+0.5f); + return buildTerrain(NULL, 1.f, center); } osg::ref_ptr TerrainGrid::buildTerrain (osg::Group* parent, float chunkSize, const osg::Vec2f& chunkCenter) @@ -100,106 +58,13 @@ osg::ref_ptr TerrainGrid::buildTerrain (osg::Group* parent, float chu } else { - float minH, maxH; - if (!mStorage->getMinMaxHeights(chunkSize, chunkCenter, minH, maxH)) - return NULL; // no terrain defined - - osg::Vec2f worldCenter = chunkCenter*mStorage->getCellWorldSize(); - osg::ref_ptr transform (new SceneUtil::PositionAttitudeTransform); - transform->setPosition(osg::Vec3f(worldCenter.x(), worldCenter.y(), 0.f)); - + osg::ref_ptr node = mChunkManager->getChunk(chunkSize, chunkCenter); + if (!node) + return NULL; if (parent) - parent->addChild(transform); - - osg::ref_ptr positions (new osg::Vec3Array); - osg::ref_ptr normals (new osg::Vec3Array); - osg::ref_ptr colors (new osg::Vec4Array); - - osg::ref_ptr vbo (new osg::VertexBufferObject); - positions->setVertexBufferObject(vbo); - normals->setVertexBufferObject(vbo); - colors->setVertexBufferObject(vbo); - - mStorage->fillVertexBuffers(0, chunkSize, chunkCenter, positions, normals, colors); - - osg::ref_ptr geometry (new TerrainDrawable); - geometry->setVertexArray(positions); - geometry->setNormalArray(normals, osg::Array::BIND_PER_VERTEX); - geometry->setColorArray(colors, osg::Array::BIND_PER_VERTEX); - geometry->setUseDisplayList(false); - geometry->setUseVertexBufferObjects(true); - - unsigned int numVerts = (mStorage->getCellVertices()-1) * chunkSize + 1; - - geometry->addPrimitiveSet(mCache.getIndexBuffer(numVerts, 0)); - - // we already know the bounding box, so no need to let OSG compute it. - osg::Vec3f min(-0.5f*mStorage->getCellWorldSize()*chunkSize, - -0.5f*mStorage->getCellWorldSize()*chunkSize, - minH); - osg::Vec3f max (0.5f*mStorage->getCellWorldSize()*chunkSize, - 0.5f*mStorage->getCellWorldSize()*chunkSize, - maxH); - osg::BoundingBox bounds(min, max); - geometry->setComputeBoundingBoxCallback(new StaticBoundingBoxCallback(bounds)); - - std::vector layerList; - std::vector > blendmaps; - mStorage->getBlendmaps(chunkSize, chunkCenter, false, blendmaps, layerList); - - bool useShaders = mResourceSystem->getSceneManager()->getForceShaders(); - if (!mResourceSystem->getSceneManager()->getClampLighting()) - useShaders = true; // always use shaders when lighting is unclamped, this is to avoid lighting seams between a terrain chunk with normal maps and one without normal maps - std::vector layers; - { - for (std::vector::const_iterator it = layerList.begin(); it != layerList.end(); ++it) - { - TextureLayer textureLayer; - textureLayer.mParallax = it->mParallax; - textureLayer.mSpecular = it->mSpecular; + parent->addChild(node); - textureLayer.mDiffuseMap = mTextureManager->getTexture(it->mDiffuseMap); - - if (!it->mNormalMap.empty()) - { - textureLayer.mNormalMap = mTextureManager->getTexture(it->mNormalMap); - } - - if (it->requiresShaders()) - useShaders = true; - - layers.push_back(textureLayer); - } - } - - std::vector > blendmapTextures; - for (std::vector >::const_iterator it = blendmaps.begin(); it != blendmaps.end(); ++it) - { - osg::ref_ptr texture (new osg::Texture2D); - texture->setImage(*it); - texture->setWrap(osg::Texture::WRAP_S, osg::Texture::CLAMP_TO_EDGE); - texture->setWrap(osg::Texture::WRAP_T, osg::Texture::CLAMP_TO_EDGE); - texture->setResizeNonPowerOfTwoHint(false); - blendmapTextures.push_back(texture); - } - - // use texture coordinates for both texture units, the layer texture and blend texture - for (unsigned int i=0; i<2; ++i) - geometry->setTexCoordArray(i, mCache.getUVBuffer(numVerts)); - - float blendmapScale = ESM::Land::LAND_TEXTURE_SIZE*chunkSize; - - geometry->setPasses(createPasses(mShaderManager ? useShaders : false, mResourceSystem->getSceneManager()->getForcePerPixelLighting(), - mResourceSystem->getSceneManager()->getClampLighting(), mShaderManager, layers, blendmapTextures, blendmapScale, blendmapScale)); - - transform->addChild(geometry); - - if (mIncrementalCompileOperation) - { - mIncrementalCompileOperation->add(geometry); - } - - return transform; + return node; } } @@ -208,27 +73,10 @@ void TerrainGrid::loadCell(int x, int y) if (mGrid.find(std::make_pair(x, y)) != mGrid.end()) return; // already loaded - // try to get it from the cache - osg::ref_ptr terrainNode; - { - OpenThreads::ScopedLock lock(mGridCacheMutex); - Grid::const_iterator found = mGridCache.find(std::make_pair(x,y)); - if (found != mGridCache.end()) - { - terrainNode = found->second; - if (!terrainNode) - return; // no terrain defined - } - } - - // didn't find in cache, build it + osg::Vec2f center(x+0.5f, y+0.5f); + osg::ref_ptr terrainNode = buildTerrain(NULL, 1.f, center); if (!terrainNode) - { - osg::Vec2f center(x+0.5f, y+0.5f); - terrainNode = buildTerrain(NULL, 1.f, center); - if (!terrainNode) - return; // no terrain defined - } + return; // no terrain defined mTerrainRoot->addChild(terrainNode); @@ -250,31 +98,9 @@ void TerrainGrid::unloadCell(int x, int y) mGrid.erase(it); } -void TerrainGrid::updateCache(double referenceTime) -{ - { - OpenThreads::ScopedLock lock(mGridCacheMutex); - for (Grid::iterator it = mGridCache.begin(); it != mGridCache.end();) - { - if (it->second->referenceCount() <= 1) - mGridCache.erase(it++); - else - ++it; - } - } -} - void TerrainGrid::updateTextureFiltering() { mTextureManager->updateTextureFiltering(); } -void TerrainGrid::reportStats(unsigned int frameNumber, osg::Stats *stats) -{ - { - OpenThreads::ScopedLock lock(mGridCacheMutex); - stats->setAttribute(frameNumber, "Terrain Cell", mGridCache.size()); - } -} - } diff --git a/components/terrain/terraingrid.hpp b/components/terrain/terraingrid.hpp index 7f6ea2d30..59d93dc6f 100644 --- a/components/terrain/terraingrid.hpp +++ b/components/terrain/terraingrid.hpp @@ -1,6 +1,8 @@ #ifndef COMPONENTS_TERRAIN_TERRAINGRID_H #define COMPONENTS_TERRAIN_TERRAINGRID_H +#include + #include #include "world.hpp" @@ -41,16 +43,10 @@ namespace Terrain /// @note Not thread safe. virtual void unloadCell(int x, int y); - /// Clear cached objects that are no longer referenced - /// @note Thread safe. - void updateCache(double referenceTime); - /// Apply the scene manager's texture filtering settings to all cached textures. /// @note Thread safe. void updateTextureFiltering(); - void reportStats(unsigned int frameNumber, osg::Stats *stats); - private: osg::ref_ptr buildTerrain (osg::Group* parent, float chunkSize, const osg::Vec2f& chunkCenter); @@ -60,11 +56,6 @@ namespace Terrain typedef std::map, osg::ref_ptr > Grid; Grid mGrid; - Grid mGridCache; - OpenThreads::Mutex mGridCacheMutex; - - BufferCache mCache; - osg::ref_ptr mUnrefQueue; Shader::ShaderManager* mShaderManager; diff --git a/components/terrain/world.cpp b/components/terrain/world.cpp index 329ed5082..007303243 100644 --- a/components/terrain/world.cpp +++ b/components/terrain/world.cpp @@ -7,6 +7,7 @@ #include "storage.hpp" #include "texturemanager.hpp" +#include "chunkmanager.hpp" namespace Terrain { @@ -26,13 +27,16 @@ World::World(osg::Group* parent, Resource::ResourceSystem* resourceSystem, osgUt mParent->addChild(mTerrainRoot); mTextureManager.reset(new TextureManager(mResourceSystem->getSceneManager())); - mResourceSystem->addResourceManager(mTextureManager.get()); + + mChunkManager.reset(new ChunkManager(mStorage, mResourceSystem->getSceneManager(), mTextureManager.get())); + mResourceSystem->addResourceManager(mChunkManager.get()); } World::~World() { mResourceSystem->removeResourceManager(mTextureManager.get()); + mResourceSystem->removeResourceManager(mChunkManager.get()); mParent->removeChild(mTerrainRoot); diff --git a/components/terrain/world.hpp b/components/terrain/world.hpp index 30d765e2d..a8cc0f0db 100644 --- a/components/terrain/world.hpp +++ b/components/terrain/world.hpp @@ -2,16 +2,17 @@ #define COMPONENTS_TERRAIN_WORLD_H #include +#include #include #include "defs.hpp" -#include "buffercache.hpp" namespace osg { class Group; class Stats; + class Node; } namespace osgUtil @@ -29,6 +30,7 @@ namespace Terrain class Storage; class TextureManager; + class ChunkManager; /** * @brief The basic interface for a terrain world. How the terrain chunks are paged and displayed @@ -46,10 +48,6 @@ namespace Terrain virtual void updateTextureFiltering() {} - virtual void updateCache(double referenceTime) {} - - virtual void reportStats(unsigned int frameNumber, osg::Stats* stats) {} - float getHeightAt (const osg::Vec3f& worldPos); virtual osg::ref_ptr cacheCell(int x, int y) {return NULL;} @@ -71,6 +69,7 @@ namespace Terrain osg::ref_ptr mIncrementalCompileOperation; std::auto_ptr mTextureManager; + std::auto_ptr mChunkManager; }; }