2014-08-07 18:43:33 +00:00
|
|
|
#ifndef COMPONENTS_TERRAIN_TERRAINGRID_H
|
|
|
|
#define COMPONENTS_TERRAIN_TERRAINGRID_H
|
2014-06-29 00:42:36 +00:00
|
|
|
|
2015-11-06 19:14:57 +00:00
|
|
|
#include <osg/Vec2f>
|
|
|
|
|
2014-08-07 18:43:33 +00:00
|
|
|
#include "world.hpp"
|
|
|
|
#include "material.hpp"
|
2014-06-29 00:42:36 +00:00
|
|
|
|
2015-06-09 00:29:56 +00:00
|
|
|
namespace osg
|
|
|
|
{
|
|
|
|
class KdTreeBuilder;
|
|
|
|
}
|
|
|
|
|
2014-06-29 00:42:36 +00:00
|
|
|
namespace Terrain
|
|
|
|
{
|
|
|
|
|
2015-06-02 23:18:36 +00:00
|
|
|
class GridElement;
|
2014-06-29 00:42:36 +00:00
|
|
|
|
|
|
|
/// @brief Simple terrain implementation that loads cells in a grid, with no LOD
|
|
|
|
class TerrainGrid : public Terrain::World
|
|
|
|
{
|
|
|
|
public:
|
2015-06-02 23:18:36 +00:00
|
|
|
TerrainGrid(osg::Group* parent, Resource::ResourceSystem* resourceSystem, osgUtil::IncrementalCompileOperation* ico,
|
|
|
|
Storage* storage, int nodeMask);
|
2014-06-29 00:42:36 +00:00
|
|
|
~TerrainGrid();
|
|
|
|
|
|
|
|
virtual void loadCell(int x, int y);
|
|
|
|
virtual void unloadCell(int x, int y);
|
|
|
|
|
|
|
|
private:
|
2015-11-06 19:14:57 +00:00
|
|
|
osg::ref_ptr<osg::Node> buildTerrain (osg::Group* parent, float chunkSize, const osg::Vec2f& chunkCenter);
|
|
|
|
|
|
|
|
// split each ESM::Cell into mNumSplits*mNumSplits terrain chunks
|
|
|
|
unsigned int mNumSplits;
|
|
|
|
|
2015-06-02 23:18:36 +00:00
|
|
|
typedef std::map<std::pair<int, int>, GridElement*> Grid;
|
2014-06-29 00:42:36 +00:00
|
|
|
Grid mGrid;
|
2015-06-09 00:29:56 +00:00
|
|
|
|
|
|
|
osg::ref_ptr<osg::KdTreeBuilder> mKdTreeBuilder;
|
2014-06-29 00:42:36 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|