52 lines
2.1 KiB
Markdown
Raw Permalink Normal View History

2025-01-22 16:18:30 +01:00
## What is recastjs ?
recastjs is a port of recastnavigation and a thin abstraction layer using emscripten. https://github.com/emscripten-core/emscripten
This port allows the use of recastnavigation in your browser using JavaScript or WebAssembly.
## What is recastnavigation ?
Recast is a navigation mesh construction toolset for games.
Recast is accompanied by Detour, a spatial reasoning toolkit.
You can use any navigation mesh with Detour, but of course the data generated by Recast fits perfectly.
The crowd management module provides you with features for agents handling and behavior customization
## How to build recastjs and haxerecast?
You'll need emscripten with an active environment and mingw32-make for Windows (make for Linux).
You'll also need Haxe and haxelib webidl installed for HL(cpp) build.
### Common
```
mkdir build
```
### JS build
```
emcmake cmake -B build -DCMAKE_BUILD_TYPE=Release
cmake --build build
```
This will produce .js and wasm version in the `build` directory.
### HL(cpp) build
```
cd Sources
haxelib dev webidl webidl
make recast.cpp
```
This will produce `recast.cpp` file in the `build` directory
Latest RecastNavigation commit : https://github.com/recastnavigation/recastnavigation/commit/c5cbd53024c8a9d8d097a4371215e3342d2fdc87
Built with emsdk 2.0.29
## How to extend recastjs ?
Recast/Detour can be difficult to use directly. A simplification layer is done thru recastnavigation/src/recastjs.h/.cpp. All the functionnalities have to be exposed to JS by the IDL file.
Basically, that file lists all the structures, classes, methods visible to JS. The glue generation and build is handled ny make.py script. Any new functionnality should be written in recastjs.cpp file and exposed by the IDL
For more information on Web IDL : https://emscripten.org/docs/porting/connecting_cpp_and_javascript/WebIDL-Binder.html
## Initial Commit
The initial commit was created from https://github.com/BabylonJS/Extensions/tree/734bc19abb04d6c38b6ffcc8a788aac08e14c8af/recastjs
## License
Recastjs is licensed under the same terms as Recastnavigation.