From 8aba74e6ee4df45cc442148e4e0b0f770b2159ef Mon Sep 17 00:00:00 2001 From: scrawl Date: Tue, 9 Feb 2016 20:23:53 +0100 Subject: [PATCH] Remove GridElement --- components/terrain/terraingrid.cpp | 20 +++++--------------- components/terrain/terraingrid.hpp | 4 +--- 2 files changed, 6 insertions(+), 18 deletions(-) diff --git a/components/terrain/terraingrid.cpp b/components/terrain/terraingrid.cpp index 4b67371e0..4d2f421e6 100644 --- a/components/terrain/terraingrid.cpp +++ b/components/terrain/terraingrid.cpp @@ -63,12 +63,6 @@ TerrainGrid::~TerrainGrid() } } -class GridElement -{ -public: - osg::ref_ptr mNode; -}; - osg::ref_ptr TerrainGrid::buildTerrain (osg::Group* parent, float chunkSize, const osg::Vec2f& chunkCenter) { if (chunkSize * mNumSplits > 1.f) @@ -208,11 +202,9 @@ void TerrainGrid::loadCell(int x, int y) if (!terrainNode) return; // no terrain defined - std::auto_ptr element (new GridElement); - element->mNode = terrainNode; - mTerrainRoot->addChild(element->mNode); + mTerrainRoot->addChild(terrainNode); - mGrid[std::make_pair(x,y)] = element.release(); + mGrid[std::make_pair(x,y)] = terrainNode; } void TerrainGrid::unloadCell(int x, int y) @@ -221,13 +213,11 @@ void TerrainGrid::unloadCell(int x, int y) if (it == mGrid.end()) return; - GridElement* element = it->second; - mTerrainRoot->removeChild(element->mNode); + osg::Node* terrainNode = it->second; + mTerrainRoot->removeChild(terrainNode); if (mUnrefQueue.get()) - mUnrefQueue->push(element->mNode); - - delete element; + mUnrefQueue->push(terrainNode); mGrid.erase(it); } diff --git a/components/terrain/terraingrid.hpp b/components/terrain/terraingrid.hpp index 5708e7068..4e6a78abd 100644 --- a/components/terrain/terraingrid.hpp +++ b/components/terrain/terraingrid.hpp @@ -14,8 +14,6 @@ namespace SceneUtil namespace Terrain { - class GridElement; - /// @brief Simple terrain implementation that loads cells in a grid, with no LOD class TerrainGrid : public Terrain::World { @@ -38,7 +36,7 @@ namespace Terrain typedef std::map > TextureCache; TextureCache mTextureCache; - typedef std::map, GridElement*> Grid; + typedef std::map, osg::ref_ptr > Grid; Grid mGrid; osg::ref_ptr mUnrefQueue;