1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-20 10:53:51 +00:00
openmw-tes3mp/components/terrain/quadtreeworld.hpp

74 lines
2.3 KiB
C++
Raw Normal View History

#ifndef COMPONENTS_TERRAIN_QUADTREEWORLD_H
#define COMPONENTS_TERRAIN_QUADTREEWORLD_H
#include "world.hpp"
#include "terraingrid.hpp"
2020-06-25 19:46:07 +00:00
#include <mutex>
2017-03-09 02:31:30 +00:00
namespace osg
{
class NodeVisitor;
}
namespace Terrain
{
class RootNode;
2017-03-09 01:03:51 +00:00
class ViewDataMap;
/// @brief Terrain implementation that loads cells into a Quad Tree, with geometry LOD and texture LOD.
class QuadTreeWorld : public TerrainGrid // note: derived from TerrainGrid is only to render default cells (see loadCell)
{
public:
QuadTreeWorld(osg::Group* parent, osg::Group* compileRoot, Resource::ResourceSystem* resourceSystem, Storage* storage, int nodeMask, int preCompileMask, int borderMask, int compMapResolution, float comMapLevel, float lodFactor, int vertexLodMod, float maxCompGeometrySize);
2019-02-20 13:37:00 +00:00
~QuadTreeWorld();
void accept(osg::NodeVisitor& nv);
void enable(bool enabled) override;
2017-03-09 01:17:25 +00:00
void setViewDistance(float distance) override { mViewDistance = distance; }
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;
void preload(View* view, const osg::Vec3f& eyePoint, const osg::Vec4i &cellgrid, std::atomic<bool>& abort, std::atomic<int>& progress, int& progressRange) override;
bool storeView(const View* view, double referenceTime) override;
void rebuildViews() override;
void reportStats(unsigned int frameNumber, osg::Stats* stats) override;
class ChunkManager
{
public:
virtual ~ChunkManager(){}
virtual osg::ref_ptr<osg::Node> getChunk(float size, const osg::Vec2f& center, unsigned char lod, unsigned int lodFlags, bool far, const osg::Vec3f& viewPoint, bool compile) = 0;
virtual unsigned int getNodeMask() { return 0; }
};
void addChunkManager(ChunkManager*);
private:
2017-03-09 02:31:30 +00:00
void ensureQuadTreeBuilt();
osg::ref_ptr<RootNode> mRootNode;
2017-03-09 01:03:51 +00:00
osg::ref_ptr<ViewDataMap> mViewDataMap;
std::vector<ChunkManager*> mChunkManagers;
2020-06-25 19:46:07 +00:00
std::mutex mQuadTreeMutex;
bool mQuadTreeBuilt;
float mLodFactor;
2019-02-20 13:37:00 +00:00
int mVertexLodMod;
float mViewDistance;
};
}
#endif