|
|
@ -5,18 +5,15 @@
|
|
|
|
#include <osg/Material>
|
|
|
|
#include <osg/Material>
|
|
|
|
#include <osg/Group>
|
|
|
|
#include <osg/Group>
|
|
|
|
|
|
|
|
|
|
|
|
#include <components/sceneutil/unrefqueue.hpp>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include "texturemanager.hpp"
|
|
|
|
#include "texturemanager.hpp"
|
|
|
|
#include "chunkmanager.hpp"
|
|
|
|
#include "chunkmanager.hpp"
|
|
|
|
|
|
|
|
|
|
|
|
namespace Terrain
|
|
|
|
namespace Terrain
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
TerrainGrid::TerrainGrid(osg::Group* parent, Resource::ResourceSystem* resourceSystem, osgUtil::IncrementalCompileOperation* ico, Storage* storage, int nodeMask, Shader::ShaderManager* shaderManager, SceneUtil::UnrefQueue* unrefQueue)
|
|
|
|
TerrainGrid::TerrainGrid(osg::Group* parent, Resource::ResourceSystem* resourceSystem, osgUtil::IncrementalCompileOperation* ico, Storage* storage, int nodeMask, Shader::ShaderManager* shaderManager)
|
|
|
|
: Terrain::World(parent, resourceSystem, ico, storage, nodeMask)
|
|
|
|
: Terrain::World(parent, resourceSystem, ico, storage, nodeMask)
|
|
|
|
, mNumSplits(4)
|
|
|
|
, mNumSplits(4)
|
|
|
|
, mUnrefQueue(unrefQueue)
|
|
|
|
|
|
|
|
, mShaderManager(shaderManager)
|
|
|
|
, mShaderManager(shaderManager)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
osg::ref_ptr<osg::Material> material (new osg::Material);
|
|
|
|
osg::ref_ptr<osg::Material> material (new osg::Material);
|
|
|
@ -92,9 +89,6 @@ void TerrainGrid::unloadCell(int x, int y)
|
|
|
|
osg::ref_ptr<osg::Node> terrainNode = it->second;
|
|
|
|
osg::ref_ptr<osg::Node> terrainNode = it->second;
|
|
|
|
mTerrainRoot->removeChild(terrainNode);
|
|
|
|
mTerrainRoot->removeChild(terrainNode);
|
|
|
|
|
|
|
|
|
|
|
|
if (mUnrefQueue.get())
|
|
|
|
|
|
|
|
mUnrefQueue->push(terrainNode);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
mGrid.erase(it);
|
|
|
|
mGrid.erase(it);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|