SharpNav is a library that generates and finds paths through navigation meshes. It is functionally equivalent to Mikko Monomen's wonderful Recast Navigation.
SharpNav is proudly an RCOS project.
There are several:
- It's portable! SharpNav is written entirely in C#, so that the same
SharpNav.dll
will run on all .NET or Mono supported platforms, no recompilation necessary. - It's fast! SharpNav was written with performance in mind and performs competitively with Recast.
- It's free! SharpNav is licensed under the MIT License.
- It's clean! SharpNav aims to maintain a clean and concise public API that matches that of the Base Class Library. It also strives to maintain clean source code by following style and structure rules enforced by both StyleCop and FxCop.
- It's integrated! SharpNav has compile configurations to integrate with various graphics toolkits and game engines. In the near future, there will be integration with game engine content pipelines as well.
SharpNav is both highly configurable and simple to use. If you want to generate a NavMesh
from a single mesh, it is as simple as the following block of code:
//prepare the geometry from your mesh data
var tris = TriangleEnumerable.FromIndexedVertices( ... );
//use the default generation settings
var settings = NavMeshGenerationSettings.Default;
settings.AgentHeight = 1.7f;
settings.AgentWidth = 0.6f;
//generate the mesh
var navMesh = NavMesh.Generate(tris, settings);
For finer control over the generation process, you can refer to the Examples project.
SharpNav is available on NuGet. It can be installed by issuing the following command in the package manager console:
PM> Install-Package SharpNav
There are also NuGet packages for the versions of SharpNav that integrate with other frameworks:
SharpNav follows the standard C# project structure. It is actively developed on Windows with Visual Studio 2012 and on Linux and OS X with MonoDevelop, so it should compile just fine in those cases.
Binaries are not output to their project's local bin
folder, they are all output to the Binaries
folder in the repository's root directory.
SharpNav can be configured to depend on other libraries. Each one has it's own compile configuration that requires the library to be installed on the machine (in the GAC or the assembly search path), with the exception being OpenTK. OpenTK is used for the Examples project, and is therefore included in the repository. If you want to compile against a different version of OpenTK, drop in your replacement in the Dependencies
folder.
SharpNav is licensed under the MIT license. The terms of the MIT license are included in both the LICENSE file and below:
The MIT License (MIT)
Copyright (c) 2013-2014 Robert Rouhani <[email protected]> and other contributors (see CONTRIBUTORS file).
SharpNav contains some altered source code from Recast Navigation, Copyright (c) 2009 Mikko Mononen [email protected]
Permission is hereby granted, free of charge, to any person obtaining a copy of
this software and associated documentation files (the "Software"), to deal in
the Software without restriction, including without limitation the rights to
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
the Software, and to permit persons to whom the Software is furnished to do so,
subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Major contributors to SharpNav are listed in the CONTRIBUTORS file.