forked from mirror/DotRecast
refactor: added RcDirectory, RcResources
This commit is contained in:
parent
502ce2efa8
commit
c1cc0fb286
|
@ -1,33 +0,0 @@
|
||||||
using System.IO;
|
|
||||||
|
|
||||||
namespace DotRecast.Core
|
|
||||||
{
|
|
||||||
public static class Loader
|
|
||||||
{
|
|
||||||
public static byte[] ToBytes(string filename)
|
|
||||||
{
|
|
||||||
var filepath = FindParentPath(filename);
|
|
||||||
using var fs = new FileStream(filepath, FileMode.Open, FileAccess.Read);
|
|
||||||
byte[] buffer = new byte[fs.Length];
|
|
||||||
fs.Read(buffer, 0, buffer.Length);
|
|
||||||
|
|
||||||
return buffer;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static string FindParentPath(string filename)
|
|
||||||
{
|
|
||||||
string filePath = Path.Combine("resources", filename);
|
|
||||||
for (int i = 0; i < 10; ++i)
|
|
||||||
{
|
|
||||||
if (File.Exists(filePath))
|
|
||||||
{
|
|
||||||
return Path.GetFullPath(filePath);
|
|
||||||
}
|
|
||||||
|
|
||||||
filePath = Path.Combine("..", filePath);
|
|
||||||
}
|
|
||||||
|
|
||||||
return Path.GetFullPath(filename);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,57 @@
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
|
namespace DotRecast.Core
|
||||||
|
{
|
||||||
|
public static class RcDirectory
|
||||||
|
{
|
||||||
|
public static string SearchPath(string searchPath, int depth, out bool isDir)
|
||||||
|
{
|
||||||
|
isDir = false;
|
||||||
|
|
||||||
|
for (int i = 0; i < depth; ++i)
|
||||||
|
{
|
||||||
|
var relativePath = string.Join("", Enumerable.Range(0, i).Select(x => "../"));
|
||||||
|
var searchingPath = Path.Combine(relativePath, searchPath);
|
||||||
|
var fullSearchingPath = Path.GetFullPath(searchingPath);
|
||||||
|
|
||||||
|
if (File.Exists(fullSearchingPath))
|
||||||
|
{
|
||||||
|
return fullSearchingPath;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Directory.Exists(fullSearchingPath))
|
||||||
|
{
|
||||||
|
isDir = true;
|
||||||
|
return fullSearchingPath;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return string.Empty;
|
||||||
|
}
|
||||||
|
|
||||||
|
// only directory
|
||||||
|
public static string SearchDirectory(string dirname, int depth = 10)
|
||||||
|
{
|
||||||
|
var searchingPath = SearchPath(dirname, depth, out var isDir);
|
||||||
|
if (!isDir)
|
||||||
|
{
|
||||||
|
var path = Path.GetDirectoryName(searchingPath) ?? string.Empty;
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
|
||||||
|
return string.Empty;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static string SearchFile(string filename, int depth = 10)
|
||||||
|
{
|
||||||
|
var searchingPath = SearchPath(filename, depth, out var isDir);
|
||||||
|
if (!isDir)
|
||||||
|
{
|
||||||
|
return searchingPath;
|
||||||
|
}
|
||||||
|
|
||||||
|
return string.Empty;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,17 @@
|
||||||
|
using System.IO;
|
||||||
|
|
||||||
|
namespace DotRecast.Core
|
||||||
|
{
|
||||||
|
public static class RcResources
|
||||||
|
{
|
||||||
|
public static byte[] Load(string filename)
|
||||||
|
{
|
||||||
|
var filepath = RcDirectory.SearchFile($"resources/{filename}");
|
||||||
|
using var fs = new FileStream(filepath, FileMode.Open, FileAccess.Read, FileShare.Read);
|
||||||
|
byte[] buffer = new byte[fs.Length];
|
||||||
|
fs.Read(buffer, 0, buffer.Length);
|
||||||
|
|
||||||
|
return buffer;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -37,11 +37,10 @@ public static class Program
|
||||||
|
|
||||||
private static void InitializeWorkingDirectory()
|
private static void InitializeWorkingDirectory()
|
||||||
{
|
{
|
||||||
var path = Loader.FindParentPath("dungeon.obj");
|
var path = RcDirectory.SearchDirectory("resources/dungeon.obj");
|
||||||
path = Path.GetDirectoryName(path);
|
|
||||||
if (!string.IsNullOrEmpty(path))
|
if (!string.IsNullOrEmpty(path))
|
||||||
{
|
{
|
||||||
var workingDirectory = Path.Combine(path, "..");
|
var workingDirectory = Path.GetDirectoryName(path) ?? string.Empty;
|
||||||
workingDirectory = Path.GetFullPath(workingDirectory);
|
workingDirectory = Path.GetFullPath(workingDirectory);
|
||||||
Directory.SetCurrentDirectory(workingDirectory);
|
Directory.SetCurrentDirectory(workingDirectory);
|
||||||
}
|
}
|
||||||
|
|
|
@ -298,7 +298,7 @@ public class RecastDemo : IRecastDemoChannel
|
||||||
|
|
||||||
private DemoInputGeomProvider LoadInputMesh(string filename)
|
private DemoInputGeomProvider LoadInputMesh(string filename)
|
||||||
{
|
{
|
||||||
var bytes = Loader.ToBytes(filename);
|
var bytes = RcResources.Load(filename);
|
||||||
DemoInputGeomProvider geom = DemoObjImporter.Load(bytes);
|
DemoInputGeomProvider geom = DemoObjImporter.Load(bytes);
|
||||||
|
|
||||||
_lastGeomFileName = filename;
|
_lastGeomFileName = filename;
|
||||||
|
@ -754,7 +754,7 @@ public class RecastDemo : IRecastDemoChannel
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
using FileStream fs = new FileStream(args.FilePath, FileMode.Open, FileAccess.Read);
|
using FileStream fs = new FileStream(args.FilePath, FileMode.Open, FileAccess.Read, FileShare.Read);
|
||||||
LoadNavMesh(fs, args.FilePath);
|
LoadNavMesh(fs, args.FilePath);
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
|
|
|
@ -88,9 +88,9 @@ public class DynamicUpdateSampleTool : ISampleTool
|
||||||
|
|
||||||
public DynamicUpdateSampleTool()
|
public DynamicUpdateSampleTool()
|
||||||
{
|
{
|
||||||
var bridgeGeom = DemoObjImporter.Load(Loader.ToBytes("bridge.obj"));
|
var bridgeGeom = DemoObjImporter.Load(RcResources.Load("bridge.obj"));
|
||||||
var houseGeom = DemoObjImporter.Load(Loader.ToBytes("house.obj"));
|
var houseGeom = DemoObjImporter.Load(RcResources.Load("house.obj"));
|
||||||
var convexGeom = DemoObjImporter.Load(Loader.ToBytes("convex.obj"));
|
var convexGeom = DemoObjImporter.Load(RcResources.Load("convex.obj"));
|
||||||
_tool = new(Random.Shared, bridgeGeom, houseGeom, convexGeom);
|
_tool = new(Random.Shared, bridgeGeom, houseGeom, convexGeom);
|
||||||
executor = Task.Factory;
|
executor = Task.Factory;
|
||||||
}
|
}
|
||||||
|
|
|
@ -142,7 +142,7 @@ namespace DotRecast.Recast.Toolset.Tools
|
||||||
|
|
||||||
public DtDynamicNavMesh Load(string filename, IRcCompressor compressor)
|
public DtDynamicNavMesh Load(string filename, IRcCompressor compressor)
|
||||||
{
|
{
|
||||||
using var fs = new FileStream(filename, FileMode.Open, FileAccess.Read);
|
using var fs = new FileStream(filename, FileMode.Open, FileAccess.Read, FileShare.Read);
|
||||||
using var br = new BinaryReader(fs);
|
using var br = new BinaryReader(fs);
|
||||||
DtVoxelFileReader reader = new DtVoxelFileReader(compressor);
|
DtVoxelFileReader reader = new DtVoxelFileReader(compressor);
|
||||||
DtVoxelFile voxelFile = reader.Read(br);
|
DtVoxelFile voxelFile = reader.Read(br);
|
||||||
|
|
|
@ -40,7 +40,7 @@ public class RecastTestMeshBuilder
|
||||||
public const float m_detailSampleMaxError = 1.0f;
|
public const float m_detailSampleMaxError = 1.0f;
|
||||||
|
|
||||||
public RecastTestMeshBuilder()
|
public RecastTestMeshBuilder()
|
||||||
: this(ObjImporter.Load(Loader.ToBytes("dungeon.obj")),
|
: this(ObjImporter.Load(RcResources.Load("dungeon.obj")),
|
||||||
RcPartition.WATERSHED,
|
RcPartition.WATERSHED,
|
||||||
m_cellSize, m_cellHeight,
|
m_cellSize, m_cellHeight,
|
||||||
m_agentMaxSlope, m_agentHeight, m_agentRadius, m_agentMaxClimb,
|
m_agentMaxSlope, m_agentHeight, m_agentRadius, m_agentMaxClimb,
|
||||||
|
|
|
@ -21,7 +21,7 @@ public class DynamicNavMeshTest
|
||||||
[Test]
|
[Test]
|
||||||
public void E2eTest()
|
public void E2eTest()
|
||||||
{
|
{
|
||||||
byte[] bytes = Loader.ToBytes("test_tiles.voxels");
|
byte[] bytes = RcResources.Load("test_tiles.voxels");
|
||||||
using var ms = new MemoryStream(bytes);
|
using var ms = new MemoryStream(bytes);
|
||||||
using var br = new BinaryReader(ms);
|
using var br = new BinaryReader(ms);
|
||||||
|
|
||||||
|
|
|
@ -30,7 +30,7 @@ public class VoxelFileReaderTest
|
||||||
[Test]
|
[Test]
|
||||||
public void ShouldReadSingleTileFile()
|
public void ShouldReadSingleTileFile()
|
||||||
{
|
{
|
||||||
byte[] bytes = Loader.ToBytes("test.voxels");
|
byte[] bytes = RcResources.Load("test.voxels");
|
||||||
using var ms = new MemoryStream(bytes);
|
using var ms = new MemoryStream(bytes);
|
||||||
using var br = new BinaryReader(ms);
|
using var br = new BinaryReader(ms);
|
||||||
|
|
||||||
|
@ -56,7 +56,7 @@ public class VoxelFileReaderTest
|
||||||
[Test]
|
[Test]
|
||||||
public void ShouldReadMultiTileFile()
|
public void ShouldReadMultiTileFile()
|
||||||
{
|
{
|
||||||
byte[] bytes = Loader.ToBytes("test_tiles.voxels");
|
byte[] bytes = RcResources.Load("test_tiles.voxels");
|
||||||
using var ms = new MemoryStream(bytes);
|
using var ms = new MemoryStream(bytes);
|
||||||
using var br = new BinaryReader(ms);
|
using var br = new BinaryReader(ms);
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@ public class VoxelFileReaderWriterTest
|
||||||
[TestCase(true)]
|
[TestCase(true)]
|
||||||
public void ShouldReadSingleTileFile(bool compression)
|
public void ShouldReadSingleTileFile(bool compression)
|
||||||
{
|
{
|
||||||
byte[] bytes = Loader.ToBytes("test.voxels");
|
byte[] bytes = RcResources.Load("test.voxels");
|
||||||
using var ms = new MemoryStream(bytes);
|
using var ms = new MemoryStream(bytes);
|
||||||
using var br = new BinaryReader(ms);
|
using var br = new BinaryReader(ms);
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ public class VoxelFileReaderWriterTest
|
||||||
[TestCase(true)]
|
[TestCase(true)]
|
||||||
public void ShouldReadMultiTileFile(bool compression)
|
public void ShouldReadMultiTileFile(bool compression)
|
||||||
{
|
{
|
||||||
byte[] bytes = Loader.ToBytes("test_tiles.voxels");
|
byte[] bytes = RcResources.Load("test_tiles.voxels");
|
||||||
using var ms = new MemoryStream(bytes);
|
using var ms = new MemoryStream(bytes);
|
||||||
using var br = new BinaryReader(ms);
|
using var br = new BinaryReader(ms);
|
||||||
|
|
||||||
|
|
|
@ -93,7 +93,7 @@ public class VoxelQueryTest
|
||||||
|
|
||||||
private DtDynamicNavMesh CreateDynaMesh()
|
private DtDynamicNavMesh CreateDynaMesh()
|
||||||
{
|
{
|
||||||
var bytes = Loader.ToBytes("test_tiles.voxels");
|
var bytes = RcResources.Load("test_tiles.voxels");
|
||||||
using var ms = new MemoryStream(bytes);
|
using var ms = new MemoryStream(bytes);
|
||||||
using var br = new BinaryReader(ms);
|
using var br = new BinaryReader(ms);
|
||||||
|
|
||||||
|
|
|
@ -81,8 +81,8 @@ public class UnityAStarPathfindingImporterTest
|
||||||
|
|
||||||
private DtNavMesh LoadNavMesh(string filename)
|
private DtNavMesh LoadNavMesh(string filename)
|
||||||
{
|
{
|
||||||
var filepath = Loader.FindParentPath(filename);
|
var filepath = RcDirectory.SearchFile($"resources/{filename}");
|
||||||
using var fs = new FileStream(filepath, FileMode.Open, FileAccess.Read);
|
using var fs = new FileStream(filepath, FileMode.Open, FileAccess.Read, FileShare.Read);
|
||||||
|
|
||||||
// Import the graphs
|
// Import the graphs
|
||||||
UnityAStarPathfindingImporter importer = new UnityAStarPathfindingImporter();
|
UnityAStarPathfindingImporter importer = new UnityAStarPathfindingImporter();
|
||||||
|
|
|
@ -32,7 +32,7 @@ public class MeshSetReaderTest
|
||||||
[Test]
|
[Test]
|
||||||
public void TestNavmesh()
|
public void TestNavmesh()
|
||||||
{
|
{
|
||||||
byte[] @is = Loader.ToBytes("all_tiles_navmesh.bin");
|
byte[] @is = RcResources.Load("all_tiles_navmesh.bin");
|
||||||
using var ms = new MemoryStream(@is);
|
using var ms = new MemoryStream(@is);
|
||||||
using var br = new BinaryReader(ms);
|
using var br = new BinaryReader(ms);
|
||||||
DtNavMesh mesh = reader.Read(br, 6);
|
DtNavMesh mesh = reader.Read(br, 6);
|
||||||
|
@ -60,7 +60,7 @@ public class MeshSetReaderTest
|
||||||
[Test]
|
[Test]
|
||||||
public void TestDungeon()
|
public void TestDungeon()
|
||||||
{
|
{
|
||||||
byte[] @is = Loader.ToBytes("dungeon_all_tiles_navmesh.bin");
|
byte[] @is = RcResources.Load("dungeon_all_tiles_navmesh.bin");
|
||||||
using var ms = new MemoryStream(@is);
|
using var ms = new MemoryStream(@is);
|
||||||
using var br = new BinaryReader(ms);
|
using var br = new BinaryReader(ms);
|
||||||
|
|
||||||
|
@ -89,7 +89,7 @@ public class MeshSetReaderTest
|
||||||
[Test]
|
[Test]
|
||||||
public void TestDungeon32Bit()
|
public void TestDungeon32Bit()
|
||||||
{
|
{
|
||||||
byte[] @is = Loader.ToBytes("dungeon_all_tiles_navmesh_32bit.bin");
|
byte[] @is = RcResources.Load("dungeon_all_tiles_navmesh_32bit.bin");
|
||||||
using var ms = new MemoryStream(@is);
|
using var ms = new MemoryStream(@is);
|
||||||
using var br = new BinaryReader(ms);
|
using var br = new BinaryReader(ms);
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,7 @@ public class MeshSetReaderWriterTest
|
||||||
[Test]
|
[Test]
|
||||||
public void Test()
|
public void Test()
|
||||||
{
|
{
|
||||||
IInputGeomProvider geom = ObjImporter.Load(Loader.ToBytes("dungeon.obj"));
|
IInputGeomProvider geom = ObjImporter.Load(RcResources.Load("dungeon.obj"));
|
||||||
|
|
||||||
NavMeshSetHeader header = new NavMeshSetHeader();
|
NavMeshSetHeader header = new NavMeshSetHeader();
|
||||||
header.magic = NavMeshSetHeader.NAVMESHSET_MAGIC;
|
header.magic = NavMeshSetHeader.NAVMESHSET_MAGIC;
|
||||||
|
|
|
@ -40,7 +40,7 @@ public class RecastTestMeshBuilder
|
||||||
private const float m_detailSampleMaxError = 1.0f;
|
private const float m_detailSampleMaxError = 1.0f;
|
||||||
|
|
||||||
public RecastTestMeshBuilder()
|
public RecastTestMeshBuilder()
|
||||||
: this(ObjImporter.Load(Loader.ToBytes("dungeon.obj")),
|
: this(ObjImporter.Load(RcResources.Load("dungeon.obj")),
|
||||||
RcPartition.WATERSHED,
|
RcPartition.WATERSHED,
|
||||||
m_cellSize, m_cellHeight,
|
m_cellSize, m_cellHeight,
|
||||||
m_agentMaxSlope, m_agentHeight, m_agentRadius, m_agentMaxClimb,
|
m_agentMaxSlope, m_agentHeight, m_agentRadius, m_agentMaxClimb,
|
||||||
|
|
|
@ -45,7 +45,7 @@ public class TestTiledNavMeshBuilder
|
||||||
private const int m_tileSize = 32;
|
private const int m_tileSize = 32;
|
||||||
|
|
||||||
public TestTiledNavMeshBuilder() :
|
public TestTiledNavMeshBuilder() :
|
||||||
this(ObjImporter.Load(Loader.ToBytes("dungeon.obj")),
|
this(ObjImporter.Load(RcResources.Load("dungeon.obj")),
|
||||||
RcPartition.WATERSHED, m_cellSize, m_cellHeight, m_agentHeight, m_agentRadius, m_agentMaxClimb, m_agentMaxSlope,
|
RcPartition.WATERSHED, m_cellSize, m_cellHeight, m_agentHeight, m_agentRadius, m_agentMaxClimb, m_agentMaxSlope,
|
||||||
m_regionMinSize, m_regionMergeSize, m_edgeMaxLen, m_edgeMaxError, m_vertsPerPoly, m_detailSampleDist,
|
m_regionMinSize, m_regionMergeSize, m_edgeMaxLen, m_edgeMaxError, m_vertsPerPoly, m_detailSampleDist,
|
||||||
m_detailSampleMaxError, m_tileSize)
|
m_detailSampleMaxError, m_tileSize)
|
||||||
|
|
|
@ -35,7 +35,7 @@ public class TileCacheReaderTest
|
||||||
[Test]
|
[Test]
|
||||||
public void TestNavmesh()
|
public void TestNavmesh()
|
||||||
{
|
{
|
||||||
using var ms = new MemoryStream(Loader.ToBytes("all_tiles_tilecache.bin"));
|
using var ms = new MemoryStream(RcResources.Load("all_tiles_tilecache.bin"));
|
||||||
using var br = new BinaryReader(ms);
|
using var br = new BinaryReader(ms);
|
||||||
DtTileCache tc = reader.Read(br, 6, null);
|
DtTileCache tc = reader.Read(br, 6, null);
|
||||||
Assert.That(tc.GetNavMesh().GetMaxTiles(), Is.EqualTo(256));
|
Assert.That(tc.GetNavMesh().GetMaxTiles(), Is.EqualTo(256));
|
||||||
|
@ -133,7 +133,7 @@ public class TileCacheReaderTest
|
||||||
[Test]
|
[Test]
|
||||||
public void TestDungeon()
|
public void TestDungeon()
|
||||||
{
|
{
|
||||||
using var ms = new MemoryStream(Loader.ToBytes("dungeon_all_tiles_tilecache.bin"));
|
using var ms = new MemoryStream(RcResources.Load("dungeon_all_tiles_tilecache.bin"));
|
||||||
using var br = new BinaryReader(ms);
|
using var br = new BinaryReader(ms);
|
||||||
DtTileCache tc = reader.Read(br, 6, null);
|
DtTileCache tc = reader.Read(br, 6, null);
|
||||||
Assert.That(tc.GetNavMesh().GetMaxTiles(), Is.EqualTo(256));
|
Assert.That(tc.GetNavMesh().GetMaxTiles(), Is.EqualTo(256));
|
||||||
|
|
|
@ -51,7 +51,7 @@ public class TileCacheReaderWriterTest : AbstractTileCacheTest
|
||||||
|
|
||||||
private void TestDungeon(bool cCompatibility)
|
private void TestDungeon(bool cCompatibility)
|
||||||
{
|
{
|
||||||
IInputGeomProvider geom = ObjImporter.Load(Loader.ToBytes("dungeon.obj"));
|
IInputGeomProvider geom = ObjImporter.Load(RcResources.Load("dungeon.obj"));
|
||||||
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
||||||
List<byte[]> layers = layerBuilder.Build(RcByteOrder.LITTLE_ENDIAN, cCompatibility, 1);
|
List<byte[]> layers = layerBuilder.Build(RcByteOrder.LITTLE_ENDIAN, cCompatibility, 1);
|
||||||
DtTileCache tc = GetTileCache(geom, RcByteOrder.LITTLE_ENDIAN, cCompatibility);
|
DtTileCache tc = GetTileCache(geom, RcByteOrder.LITTLE_ENDIAN, cCompatibility);
|
||||||
|
|
|
@ -34,7 +34,7 @@ public class TempObstaclesTest : AbstractTileCacheTest
|
||||||
public void TestDungeon()
|
public void TestDungeon()
|
||||||
{
|
{
|
||||||
bool cCompatibility = true;
|
bool cCompatibility = true;
|
||||||
IInputGeomProvider geom = ObjImporter.Load(Loader.ToBytes("dungeon.obj"));
|
IInputGeomProvider geom = ObjImporter.Load(RcResources.Load("dungeon.obj"));
|
||||||
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
||||||
List<byte[]> layers = layerBuilder.Build(RcByteOrder.LITTLE_ENDIAN, cCompatibility, 1);
|
List<byte[]> layers = layerBuilder.Build(RcByteOrder.LITTLE_ENDIAN, cCompatibility, 1);
|
||||||
DtTileCache tc = GetTileCache(geom, RcByteOrder.LITTLE_ENDIAN, cCompatibility);
|
DtTileCache tc = GetTileCache(geom, RcByteOrder.LITTLE_ENDIAN, cCompatibility);
|
||||||
|
@ -68,7 +68,7 @@ public class TempObstaclesTest : AbstractTileCacheTest
|
||||||
public void TestDungeonBox()
|
public void TestDungeonBox()
|
||||||
{
|
{
|
||||||
bool cCompatibility = true;
|
bool cCompatibility = true;
|
||||||
IInputGeomProvider geom = ObjImporter.Load(Loader.ToBytes("dungeon.obj"));
|
IInputGeomProvider geom = ObjImporter.Load(RcResources.Load("dungeon.obj"));
|
||||||
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
||||||
List<byte[]> layers = layerBuilder.Build(RcByteOrder.LITTLE_ENDIAN, cCompatibility, 1);
|
List<byte[]> layers = layerBuilder.Build(RcByteOrder.LITTLE_ENDIAN, cCompatibility, 1);
|
||||||
DtTileCache tc = GetTileCache(geom, RcByteOrder.LITTLE_ENDIAN, cCompatibility);
|
DtTileCache tc = GetTileCache(geom, RcByteOrder.LITTLE_ENDIAN, cCompatibility);
|
||||||
|
|
|
@ -38,7 +38,7 @@ public class TileCacheFindPathTest : AbstractTileCacheTest
|
||||||
|
|
||||||
public TileCacheFindPathTest()
|
public TileCacheFindPathTest()
|
||||||
{
|
{
|
||||||
using var msr = new MemoryStream(Loader.ToBytes("dungeon_all_tiles_tilecache.bin"));
|
using var msr = new MemoryStream(RcResources.Load("dungeon_all_tiles_tilecache.bin"));
|
||||||
using var br = new BinaryReader(msr);
|
using var br = new BinaryReader(msr);
|
||||||
DtTileCache tcC = new DtTileCacheReader(DtTileCacheCompressorFactory.Shared).Read(br, 6, new TestTileCacheMeshProcess());
|
DtTileCache tcC = new DtTileCacheReader(DtTileCacheCompressorFactory.Shared).Read(br, 6, new TestTileCacheMeshProcess());
|
||||||
navmesh = tcC.GetNavMesh();
|
navmesh = tcC.GetNavMesh();
|
||||||
|
|
|
@ -55,7 +55,7 @@ public class TileCacheNavigationTest : AbstractTileCacheTest
|
||||||
public void SetUp()
|
public void SetUp()
|
||||||
{
|
{
|
||||||
bool cCompatibility = true;
|
bool cCompatibility = true;
|
||||||
IInputGeomProvider geom = ObjImporter.Load(Loader.ToBytes("dungeon.obj"));
|
IInputGeomProvider geom = ObjImporter.Load(RcResources.Load("dungeon.obj"));
|
||||||
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
||||||
List<byte[]> layers = layerBuilder.Build(RcByteOrder.LITTLE_ENDIAN, cCompatibility, 1);
|
List<byte[]> layers = layerBuilder.Build(RcByteOrder.LITTLE_ENDIAN, cCompatibility, 1);
|
||||||
DtTileCache tc = GetTileCache(geom, RcByteOrder.LITTLE_ENDIAN, cCompatibility);
|
DtTileCache tc = GetTileCache(geom, RcByteOrder.LITTLE_ENDIAN, cCompatibility);
|
||||||
|
|
|
@ -59,7 +59,7 @@ public class TileCacheTest : AbstractTileCacheTest
|
||||||
|
|
||||||
private void TestDungeon(RcByteOrder order, bool cCompatibility)
|
private void TestDungeon(RcByteOrder order, bool cCompatibility)
|
||||||
{
|
{
|
||||||
IInputGeomProvider geom = ObjImporter.Load(Loader.ToBytes("dungeon.obj"));
|
IInputGeomProvider geom = ObjImporter.Load(RcResources.Load("dungeon.obj"));
|
||||||
DtTileCache tc = GetTileCache(geom, order, cCompatibility);
|
DtTileCache tc = GetTileCache(geom, order, cCompatibility);
|
||||||
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
||||||
List<byte[]> layers = layerBuilder.Build(order, cCompatibility, 1);
|
List<byte[]> layers = layerBuilder.Build(order, cCompatibility, 1);
|
||||||
|
@ -155,7 +155,7 @@ public class TileCacheTest : AbstractTileCacheTest
|
||||||
|
|
||||||
private void Test(RcByteOrder order, bool cCompatibility)
|
private void Test(RcByteOrder order, bool cCompatibility)
|
||||||
{
|
{
|
||||||
IInputGeomProvider geom = ObjImporter.Load(Loader.ToBytes("nav_test.obj"));
|
IInputGeomProvider geom = ObjImporter.Load(RcResources.Load("nav_test.obj"));
|
||||||
DtTileCache tc = GetTileCache(geom, order, cCompatibility);
|
DtTileCache tc = GetTileCache(geom, order, cCompatibility);
|
||||||
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
||||||
List<byte[]> layers = layerBuilder.Build(order, cCompatibility, 1);
|
List<byte[]> layers = layerBuilder.Build(order, cCompatibility, 1);
|
||||||
|
@ -182,7 +182,7 @@ public class TileCacheTest : AbstractTileCacheTest
|
||||||
RcByteOrder order = RcByteOrder.LITTLE_ENDIAN;
|
RcByteOrder order = RcByteOrder.LITTLE_ENDIAN;
|
||||||
bool cCompatibility = false;
|
bool cCompatibility = false;
|
||||||
|
|
||||||
var objBytes = Loader.ToBytes("dungeon.obj");
|
var objBytes = RcResources.Load("dungeon.obj");
|
||||||
IInputGeomProvider geom = ObjImporter.Load(objBytes);
|
IInputGeomProvider geom = ObjImporter.Load(objBytes);
|
||||||
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
TestTileLayerBuilder layerBuilder = new TestTileLayerBuilder(geom);
|
||||||
for (int i = 0; i < 4; i++)
|
for (int i = 0; i < 4; i++)
|
||||||
|
|
|
@ -145,7 +145,7 @@ public class RecastLayersTest
|
||||||
|
|
||||||
private RcHeightfieldLayerSet Build(string filename, int x, int y)
|
private RcHeightfieldLayerSet Build(string filename, int x, int y)
|
||||||
{
|
{
|
||||||
IInputGeomProvider geom = ObjImporter.Load(Loader.ToBytes(filename));
|
IInputGeomProvider geom = ObjImporter.Load(RcResources.Load(filename));
|
||||||
RecastBuilder builder = new RecastBuilder();
|
RecastBuilder builder = new RecastBuilder();
|
||||||
RcConfig cfg = new RcConfig(true, m_tileSize, m_tileSize,
|
RcConfig cfg = new RcConfig(true, m_tileSize, m_tileSize,
|
||||||
RcConfig.CalcBorder(m_agentRadius, m_cellSize),
|
RcConfig.CalcBorder(m_agentRadius, m_cellSize),
|
||||||
|
|
|
@ -96,7 +96,7 @@ public class RecastSoloMeshTest
|
||||||
int expContours, int expVerts, int expPolys, int expDetMeshes, int expDetVerts, int expDetTris)
|
int expContours, int expVerts, int expPolys, int expDetMeshes, int expDetVerts, int expDetTris)
|
||||||
{
|
{
|
||||||
m_partitionType = partitionType;
|
m_partitionType = partitionType;
|
||||||
IInputGeomProvider geomProvider = ObjImporter.Load(Loader.ToBytes(filename));
|
IInputGeomProvider geomProvider = ObjImporter.Load(RcResources.Load(filename));
|
||||||
long time = RcFrequency.Ticks;
|
long time = RcFrequency.Ticks;
|
||||||
RcVec3f bmin = geomProvider.GetMeshBoundsMin();
|
RcVec3f bmin = geomProvider.GetMeshBoundsMin();
|
||||||
RcVec3f bmax = geomProvider.GetMeshBoundsMax();
|
RcVec3f bmax = geomProvider.GetMeshBoundsMax();
|
||||||
|
|
|
@ -58,7 +58,7 @@ public class RecastTileMeshTest
|
||||||
|
|
||||||
public void TestBuild(string filename)
|
public void TestBuild(string filename)
|
||||||
{
|
{
|
||||||
IInputGeomProvider geom = ObjImporter.Load(Loader.ToBytes(filename));
|
IInputGeomProvider geom = ObjImporter.Load(RcResources.Load(filename));
|
||||||
RecastBuilder builder = new RecastBuilder();
|
RecastBuilder builder = new RecastBuilder();
|
||||||
RcConfig cfg = new RcConfig(
|
RcConfig cfg = new RcConfig(
|
||||||
true, m_tileSize, m_tileSize, RcConfig.CalcBorder(m_agentRadius, m_cellSize),
|
true, m_tileSize, m_tileSize, RcConfig.CalcBorder(m_agentRadius, m_cellSize),
|
||||||
|
@ -100,7 +100,7 @@ public class RecastTileMeshTest
|
||||||
[Test]
|
[Test]
|
||||||
public void TestPerformance()
|
public void TestPerformance()
|
||||||
{
|
{
|
||||||
IInputGeomProvider geom = ObjImporter.Load(Loader.ToBytes("dungeon.obj"));
|
IInputGeomProvider geom = ObjImporter.Load(RcResources.Load("dungeon.obj"));
|
||||||
RecastBuilder builder = new RecastBuilder();
|
RecastBuilder builder = new RecastBuilder();
|
||||||
RcConfig cfg = new RcConfig(
|
RcConfig cfg = new RcConfig(
|
||||||
true, m_tileSize, m_tileSize,
|
true, m_tileSize, m_tileSize,
|
||||||
|
|
Loading…
Reference in New Issue