I’m having strange behaviour with NavMesh. When I enable bCanAffectNavigation on Pawn in runtime, the rebuilded NavMesh uses default agent size instead of what is set in RecastNavMesh-Default actor or in Project settings.
This is happening in my main game project but I made a small repro project to demonstrate the issue.
Here are my NavMesh settings:
RecastNavMesh-Default actor
Project Settings
When CanAffectNavigation is disabled the NavMesh is built fine:
I can confirm it still exists in 4.7.2 and is quite troublesome. And as Fervensimber it works in the editor until you actually play it and the recast bugged:
Thanks for trying it out. In 4.7.2 the behaviour is still bugged. In editor the NavMesh is cast correctly but if you hit play and click on the character the navmesh tile with the char in it is recast with wrong agent size.
Thank you for the report. I was able to reproduce the issue and have submitted JIRA UE-11956. Our developers will be investigating the issue further and we will post here with updates as we get them.
Not only does it change if you update at runtime, it also changes if you update it period.
I’m not updating the navmesh at runtime, and I set the Agent Radius in my Project Settings to be 200, but after closing the project and reopening, The radius did not update. I then manually set the Agent Radius in the RecastNavMesh-Default actor in the world outliner, and this DID update the value, however, upon restarting the project, the values were reset back to the defaults.
This issue is happening in UE 5.3 - I’m going to submit a new report since I just realized this thread is 9 years old.
If anyone else runs into this issue, I was able to solve it by creating my own Agent in the Supported Agents list. I simply clicked on the + and set my agent radius there and gave it an agent name of Custom. Then I deleted the RecastNavMesh - Default actor, and built the paths again. This caused a new RecastNavMesh - Custom actor to be added to the level, and I’ve tested that restarting the project keeps my custom data. Frustrating to say the least, but at least there’s a workaround.
For those who are going to try this solution, I ended up finding a bug, if you create a new agent it seems that the pawns that were already at the level will ignore the new navmesh. Deleting them and putting them back in solves the problem. This does not happen with pawns that are created at runtime
Interesting and good to know. Though I really recommend you use the Player Start and actually spawn your pawn rather than possessing one you drop in the level anyway. It’s the proper way to do this. If you’re wanting to be able to switch pawns to things like vehicles etc., I even suggest using a dummy actor that you can interact with and then removing it and replacing it with a spawned pawn at runtime.