2018-03-14 01:49:08 +03:00
|
|
|
#include "debug.hpp"
|
|
|
|
#include "exceptions.hpp"
|
|
|
|
#include "recastmesh.hpp"
|
2021-10-06 17:36:05 +02:00
|
|
|
#include "settings.hpp"
|
|
|
|
#include "settingsutils.hpp"
|
2018-03-14 01:49:08 +03:00
|
|
|
|
|
|
|
#include <DetourNavMesh.h>
|
|
|
|
|
2022-05-25 18:29:02 +00:00
|
|
|
#include <filesystem>
|
|
|
|
#include <fstream>
|
2018-03-14 01:49:08 +03:00
|
|
|
|
|
|
|
namespace DetourNavigator
|
|
|
|
{
|
2021-11-06 13:46:43 +01:00
|
|
|
void writeToFile(const RecastMesh& recastMesh, const std::string& pathPrefix,
|
|
|
|
const std::string& revision, const RecastSettings& settings)
|
2018-03-14 01:49:08 +03:00
|
|
|
{
|
2018-04-02 09:55:12 +03:00
|
|
|
const auto path = pathPrefix + "recastmesh" + revision + ".obj";
|
2022-05-25 18:29:02 +00:00
|
|
|
std::ofstream file(std::filesystem::path(path), std::ios::out);
|
2018-03-14 01:49:08 +03:00
|
|
|
if (!file.is_open())
|
|
|
|
throw NavigatorException("Open file failed: " + path);
|
|
|
|
file.exceptions(std::ios::failbit | std::ios::badbit);
|
|
|
|
file.precision(std::numeric_limits<float>::max_exponent10);
|
2021-10-06 17:36:05 +02:00
|
|
|
std::vector<float> vertices = recastMesh.getMesh().getVertices();
|
|
|
|
for (std::size_t i = 0; i < vertices.size(); i += 3)
|
2018-03-14 01:49:08 +03:00
|
|
|
{
|
2021-10-06 17:36:05 +02:00
|
|
|
file << "v " << toNavMeshCoordinates(settings, vertices[i]) << ' '
|
|
|
|
<< toNavMeshCoordinates(settings, vertices[i + 2]) << ' '
|
|
|
|
<< toNavMeshCoordinates(settings, vertices[i + 1]) << '\n';
|
2018-03-14 01:49:08 +03:00
|
|
|
}
|
2021-10-06 17:36:05 +02:00
|
|
|
std::size_t count = 0;
|
2021-07-11 21:43:19 +02:00
|
|
|
for (int v : recastMesh.getMesh().getIndices())
|
2018-03-14 01:49:08 +03:00
|
|
|
{
|
|
|
|
if (count % 3 == 0)
|
|
|
|
{
|
|
|
|
if (count != 0)
|
|
|
|
file << '\n';
|
|
|
|
file << 'f';
|
|
|
|
}
|
|
|
|
file << ' ' << (v + 1);
|
|
|
|
++count;
|
|
|
|
}
|
|
|
|
file << '\n';
|
|
|
|
}
|
|
|
|
|
2018-04-01 18:09:43 +03:00
|
|
|
void writeToFile(const dtNavMesh& navMesh, const std::string& pathPrefix, const std::string& revision)
|
2018-03-14 01:49:08 +03:00
|
|
|
{
|
2018-04-01 18:09:43 +03:00
|
|
|
const int navMeshSetMagic = 'M' << 24 | 'S' << 16 | 'E' << 8 | 'T'; //'MSET';
|
|
|
|
const int navMeshSetVersion = 1;
|
|
|
|
|
|
|
|
struct NavMeshSetHeader
|
2018-03-14 01:49:08 +03:00
|
|
|
{
|
2018-04-01 18:09:43 +03:00
|
|
|
int magic;
|
|
|
|
int version;
|
|
|
|
int numTiles;
|
|
|
|
dtNavMeshParams params;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct NavMeshTileHeader
|
2018-03-14 01:49:08 +03:00
|
|
|
{
|
2018-04-01 18:09:43 +03:00
|
|
|
dtTileRef tileRef;
|
|
|
|
int dataSize;
|
|
|
|
};
|
2018-03-14 01:49:08 +03:00
|
|
|
|
2018-04-02 09:55:12 +03:00
|
|
|
const auto path = pathPrefix + "all_tiles_navmesh" + revision + ".bin";
|
2022-05-25 18:29:02 +00:00
|
|
|
std::ofstream file(std::filesystem::path(path), std::ios::out | std::ios::binary);
|
2018-03-14 01:49:08 +03:00
|
|
|
if (!file.is_open())
|
|
|
|
throw NavigatorException("Open file failed: " + path);
|
|
|
|
file.exceptions(std::ios::failbit | std::ios::badbit);
|
|
|
|
|
|
|
|
NavMeshSetHeader header;
|
2018-04-01 18:09:43 +03:00
|
|
|
header.magic = navMeshSetMagic;
|
|
|
|
header.version = navMeshSetVersion;
|
2018-03-14 01:49:08 +03:00
|
|
|
header.numTiles = 0;
|
|
|
|
for (int i = 0; i < navMesh.getMaxTiles(); ++i)
|
|
|
|
{
|
|
|
|
const auto tile = navMesh.getTile(i);
|
|
|
|
if (!tile || !tile->header || !tile->dataSize)
|
|
|
|
continue;
|
|
|
|
header.numTiles++;
|
|
|
|
}
|
|
|
|
header.params = *navMesh.getParams();
|
|
|
|
|
|
|
|
using const_char_ptr = const char*;
|
|
|
|
file.write(const_char_ptr(&header), sizeof(header));
|
|
|
|
|
|
|
|
for (int i = 0; i < navMesh.getMaxTiles(); ++i)
|
|
|
|
{
|
|
|
|
const auto tile = navMesh.getTile(i);
|
|
|
|
if (!tile || !tile->header || !tile->dataSize)
|
|
|
|
continue;
|
|
|
|
|
|
|
|
NavMeshTileHeader tileHeader;
|
|
|
|
tileHeader.tileRef = navMesh.getTileRef(tile);
|
|
|
|
tileHeader.dataSize = tile->dataSize;
|
|
|
|
|
|
|
|
file.write(const_char_ptr(&tileHeader), sizeof(tileHeader));
|
|
|
|
file.write(const_char_ptr(tile->data), tile->dataSize);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|