|
|
@ -5,6 +5,7 @@
|
|
|
|
#include <components/esm3/loadland.hpp>
|
|
|
|
#include <components/esm3/loadland.hpp>
|
|
|
|
|
|
|
|
|
|
|
|
#include <algorithm>
|
|
|
|
#include <algorithm>
|
|
|
|
|
|
|
|
#include <iterator>
|
|
|
|
#include <random>
|
|
|
|
#include <random>
|
|
|
|
|
|
|
|
|
|
|
|
namespace
|
|
|
|
namespace
|
|
|
@ -24,29 +25,25 @@ namespace
|
|
|
|
PreparedNavMeshData mValue;
|
|
|
|
PreparedNavMeshData mValue;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
template <typename Random>
|
|
|
|
osg::Vec2i generateVec2i(int max, auto& random)
|
|
|
|
osg::Vec2i generateVec2i(int max, Random& random)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::uniform_int_distribution<int> distribution(0, max);
|
|
|
|
std::uniform_int_distribution<int> distribution(0, max);
|
|
|
|
return osg::Vec2i(distribution(random), distribution(random));
|
|
|
|
return osg::Vec2i(distribution(random), distribution(random));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <typename Random>
|
|
|
|
osg::Vec3f generateAgentHalfExtents(float min, float max, auto& random)
|
|
|
|
osg::Vec3f generateAgentHalfExtents(float min, float max, Random& random)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::uniform_int_distribution<int> distribution(min, max);
|
|
|
|
std::uniform_int_distribution<int> distribution(min, max);
|
|
|
|
return osg::Vec3f(distribution(random), distribution(random), distribution(random));
|
|
|
|
return osg::Vec3f(distribution(random), distribution(random), distribution(random));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <typename OutputIterator, typename Random>
|
|
|
|
void generateVertices(std::output_iterator<int> auto out, std::size_t number, auto& random)
|
|
|
|
void generateVertices(OutputIterator out, std::size_t number, Random& random)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::uniform_real_distribution<float> distribution(0.0, 1.0);
|
|
|
|
std::uniform_real_distribution<float> distribution(0.0, 1.0);
|
|
|
|
std::generate_n(out, 3 * (number - number % 3), [&] { return distribution(random); });
|
|
|
|
std::generate_n(out, 3 * (number - number % 3), [&] { return distribution(random); });
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <typename OutputIterator, typename Random>
|
|
|
|
void generateIndices(std::output_iterator<int> auto out, int max, std::size_t number, auto& random)
|
|
|
|
void generateIndices(OutputIterator out, int max, std::size_t number, Random& random)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::uniform_int_distribution<int> distribution(0, max);
|
|
|
|
std::uniform_int_distribution<int> distribution(0, max);
|
|
|
|
std::generate_n(out, number - number % 3, [&] { return distribution(random); });
|
|
|
|
std::generate_n(out, number - number % 3, [&] { return distribution(random); });
|
|
|
@ -70,21 +67,18 @@ namespace
|
|
|
|
return AreaType_null;
|
|
|
|
return AreaType_null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <typename Random>
|
|
|
|
AreaType generateAreaType(auto& random)
|
|
|
|
AreaType generateAreaType(Random& random)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::uniform_int_distribution<int> distribution(0, 4);
|
|
|
|
std::uniform_int_distribution<int> distribution(0, 4);
|
|
|
|
return toAreaType(distribution(random));
|
|
|
|
return toAreaType(distribution(random));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <typename OutputIterator, typename Random>
|
|
|
|
void generateAreaTypes(std::output_iterator<AreaType> auto out, std::size_t triangles, auto& random)
|
|
|
|
void generateAreaTypes(OutputIterator out, std::size_t triangles, Random& random)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::generate_n(out, triangles, [&] { return generateAreaType(random); });
|
|
|
|
std::generate_n(out, triangles, [&] { return generateAreaType(random); });
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <typename OutputIterator, typename Random>
|
|
|
|
void generateWater(std::output_iterator<CellWater> auto out, std::size_t count, auto& random)
|
|
|
|
void generateWater(OutputIterator out, std::size_t count, Random& random)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::uniform_real_distribution<float> distribution(0.0, 1.0);
|
|
|
|
std::uniform_real_distribution<float> distribution(0.0, 1.0);
|
|
|
|
std::generate_n(out, count, [&] {
|
|
|
|
std::generate_n(out, count, [&] {
|
|
|
@ -92,8 +86,7 @@ namespace
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <class Random>
|
|
|
|
Mesh generateMesh(std::size_t triangles, auto& random)
|
|
|
|
Mesh generateMesh(std::size_t triangles, Random& random)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::uniform_real_distribution<float> distribution(0.0, 1.0);
|
|
|
|
std::uniform_real_distribution<float> distribution(0.0, 1.0);
|
|
|
|
std::vector<float> vertices;
|
|
|
|
std::vector<float> vertices;
|
|
|
@ -109,8 +102,7 @@ namespace
|
|
|
|
return Mesh(std::move(indices), std::move(vertices), std::move(areaTypes));
|
|
|
|
return Mesh(std::move(indices), std::move(vertices), std::move(areaTypes));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <class Random>
|
|
|
|
Heightfield generateHeightfield(auto& random)
|
|
|
|
Heightfield generateHeightfield(Random& random)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::uniform_real_distribution<float> distribution(0.0, 1.0);
|
|
|
|
std::uniform_real_distribution<float> distribution(0.0, 1.0);
|
|
|
|
Heightfield result;
|
|
|
|
Heightfield result;
|
|
|
@ -127,8 +119,7 @@ namespace
|
|
|
|
return result;
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <class Random>
|
|
|
|
FlatHeightfield generateFlatHeightfield(auto& random)
|
|
|
|
FlatHeightfield generateFlatHeightfield(Random& random)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::uniform_real_distribution<float> distribution(0.0, 1.0);
|
|
|
|
std::uniform_real_distribution<float> distribution(0.0, 1.0);
|
|
|
|
FlatHeightfield result;
|
|
|
|
FlatHeightfield result;
|
|
|
@ -138,8 +129,7 @@ namespace
|
|
|
|
return result;
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <class Random>
|
|
|
|
Key generateKey(std::size_t triangles, auto& random)
|
|
|
|
Key generateKey(std::size_t triangles, Random& random)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
const CollisionShapeType agentShapeType = CollisionShapeType::Aabb;
|
|
|
|
const CollisionShapeType agentShapeType = CollisionShapeType::Aabb;
|
|
|
|
const osg::Vec3f agentHalfExtents = generateAgentHalfExtents(0.5, 1.5, random);
|
|
|
|
const osg::Vec3f agentHalfExtents = generateAgentHalfExtents(0.5, 1.5, random);
|
|
|
@ -158,14 +148,12 @@ namespace
|
|
|
|
|
|
|
|
|
|
|
|
constexpr std::size_t trianglesPerTile = 239;
|
|
|
|
constexpr std::size_t trianglesPerTile = 239;
|
|
|
|
|
|
|
|
|
|
|
|
template <typename OutputIterator, typename Random>
|
|
|
|
void generateKeys(std::output_iterator<Key> auto out, std::size_t count, auto& random)
|
|
|
|
void generateKeys(OutputIterator out, std::size_t count, Random& random)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::generate_n(out, count, [&] { return generateKey(trianglesPerTile, random); });
|
|
|
|
std::generate_n(out, count, [&] { return generateKey(trianglesPerTile, random); });
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <typename OutputIterator, typename Random>
|
|
|
|
void fillCache(std::output_iterator<Key> auto out, auto& random, NavMeshTilesCache& cache)
|
|
|
|
void fillCache(OutputIterator out, Random& random, NavMeshTilesCache& cache)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::size_t size = cache.getStats().mNavMeshCacheSize;
|
|
|
|
std::size_t size = cache.getStats().mNavMeshCacheSize;
|
|
|
|
|
|
|
|
|
|
|
|