-
-
Notifications
You must be signed in to change notification settings - Fork 21.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
NavigationAgent2D does not apply radius settings around NavigationPolygonInstance in 3.5 beta 4 #60546
Comments
Maybe? #60354 seems to show a 3D navmesh correctly baking the safety radius, but then the NavigationAgent3D is traveling outside the navmesh for some reason. #57486 seems to show a NavigationAgent2D responding in apparently suboptimal ways to a NavigationObstacle2D - although it is correctly using the radius to avoid the NavigationObstacle2D. This issue is a NavigationAgent2D not employing the radius when navigating around a NavigationPolygonInstance. I'm not using any NavigationObstacle2D. (Not saying they're not related under the hood, just wanted to document what I perceived the differences between the issues to be) |
@Calinou I think the milestone for this one should be Regarding the issue itself, it's unrelated to The issue here is due to the fundamental problem of In In The only way to overcome this problem would be IMO to introduce a new option to the @nathanielhudson would such an option be satisfactory to you? |
This sounds like a difficult problem to tackle for 3.5, so I'd prefer keeping the milestone to |
ok, sounds reasonable |
@Scony - Tile centers would be good for my use case, but it might be a problem for others - tile centers assumes that the tiles are approximately the same size as the agents - If I had small tiles and big agents, it may not work. I feel that ideally we'd have either the navmesh or agent be smart enough to take the agent's radius into account. Spitballing here... it would be neat if the navmesh or agent could internally cache a modified version of the navmesh geometry contracted by the agents' sizes. For example, my 10px agent goes to make a path and creates a new version of the navmesh geometry |
IMO that's only doable with baking stage implemented. |
Fair. At risk of asking a dumb question, is there a reason why 2D has no bake? |
It was never implemented. Till |
@nathanielhudson E.g. get the NavigationMesh from your 2D NavigationPolygon resource. Convert the navmesh back to a "real" mesh for a meshinstance node that is a child of a NavigationMeshinstance / NavigationRegion3D and bake your agent. Then upload this navmesh to the NavigationServer3D with the map RID of your World2D / Navigation2D and the region RID of your NavigationPolygonInstance / NavigationRegion2D. |
@smix8 |
This is very disappointing. I have been avoiding the current Godot3 Navigation2D exactly because entities get stuck on corners and was hoping the new navigation solution in Godot 3.5 and Godot4 to solve this long standing issue. It's great we now have it built-into 3D navigation, but the vast majority of Godot users are still using Godot for 2D as recent poll shows. |
The navigationmesh for both 2D and 3D edges are where the center of the actor can move. Users cannot place a collision wall at the actors center and expect things to work in both 2D and 3D. EDIT |
I have the same problem in Godot 3.5. My workaround was reducing the collision polygon of the walls. However, that create a lot of issues and create a strange feeling because the characters move too near to walls (especially in corners). It will be nice if we can configure a radius for the navigation agent. Any other solution? |
@AlejandroMonteseirin |
As a workaround, you can set the navigatable area to be half the size of the tile (tile size minus double the character's radius to be precise): Then set "Edge Connection Margin" to half the tile size (double the character's radius). It can be set in the project settings dialog at |
That is a nice workaround. If you have all entities of the same size it may work great. If you have entities of different sizes you may still have some issues. IMO NavigationAgent2D will still need to have a radius setting so that different sized agents can use the same navmesh. |
Unfortunately that work around doesn't work for my situation, as the walls in my map are much thinner than the total tile size, so if i make a margin big enough to connect the little island navmesh pieces like you have in the gif above, then the agents can form paths through the walls. I'm also quite nonplussed at how you're able to get such uniform perfect navmeshes on ur tiles, I couldn't find a grid feature when trying to make mine. there is a snap feature, but no grid: Also, yeah I have enemies of different sizes anyway |
@smix8 any updates on this? |
Hey! Just checking this will be in Godot version 3.*? I really would like to have this feature 🙏 (worries me that most commercial games would be using v3 at present and it isn't feasible to use Godot 4... yet). |
@smks Godot 4.1+ only. |
Here is the code I'm using: extends CharacterBody2D
var movement_speed: float = 20.0
var movement_target_position: Vector2 = Vector2(350.0, 190.0)
@onready var navigation_agent: NavigationAgent2D = $NavigationAgent2D
@onready var navigation_region: NavigationRegion2D = $"../NavigationRegion2D"
func _ready():
# These values need to be adjusted for the actor's speed
# and the navigation layout.
navigation_agent.path_desired_distance = 4.0
navigation_agent.target_desired_distance = 4.0
# Make sure to not await during _ready.
call_deferred("actor_setup")
func actor_setup():
### MY ADDITION BELOW
var navigation_map: RID = NavigationServer3D.map_create()
var navigation_mesh: NavigationMesh = navigation_region.navigation_polygon.get_navigation_mesh()
navigation_mesh.agent_radius = 10.0
NavigationMeshGenerator.bake(navigation_mesh, self)
NavigationServer3D.region_set_navigation_mesh(navigation_region.get_region_rid(), navigation_mesh)
NavigationServer3D.region_set_map(navigation_region.get_region_rid(), navigation_map)
NavigationServer3D.map_set_cell_size(navigation_map, 1.0)
NavigationServer3D.map_force_update(navigation_map)
navigation_agent.set_navigation_map(navigation_map)
### MY ADDITION ABOVE
# Wait for the first physics frame so the NavigationServer can sync.
await get_tree().physics_frame
# Now that the navigation map is no longer empty, set the movement target.
set_movement_target(movement_target_position)
func set_movement_target(movement_target: Vector2):
navigation_agent.target_position = movement_target
func _physics_process(_delta):
if navigation_agent.is_navigation_finished():
return
var current_agent_position: Vector2 = global_position
var next_path_position: Vector2 = navigation_agent.get_next_path_position()
var new_velocity: Vector2 = next_path_position - current_agent_position
new_velocity = new_velocity.normalized()
new_velocity = new_velocity * movement_speed
velocity = new_velocity
move_and_slide() |
I could make it work eventually. Here is the solution I used: func actor_setup():
### MY ADDITION BELOW
var radius: float = -10.0
var tab: Array[PackedVector2Array]
var polygon = NavigationPolygon.new()
var outline = navigation_region.navigation_polygon.get_outline(0)
tab = Geometry2D.offset_polygon(outline, radius)
polygon.add_outline(tab[0])
polygon.make_polygons_from_outlines()
navigation_region.navigation_polygon = polygon
### MY ADDITION ABOVE
# Wait for the first physics frame so the NavigationServer can sync.
await get_tree().physics_frame
# Now that the navigation map is no longer empty, set the movement target.
set_movement_target(movement_target_position) |
Godot version
v3.5.beta4.official [b6968ab]
System information
Windows 10
Issue description
Hello. Apologies if I've misunderstood anything and/or have made a stupid mistake here.
I have a NavigationAgent2D on which I am setting a radius. However, that radius does not seem to be affecting the paths provided by $NavigationAgent.get_next_location() and $NavigationAgent.get_nav_path(). The returned paths are hugging tight to corners and walls, whereas I would expect them to be offset by the radius value.
Steps to reproduce
Download and run the reproduction project. Despite a radius being set in the navigationagent (as confirmed with a print output), it hugs right to corners as if radius was 0.
Minimal reproduction project
Learning 3.zip
The text was updated successfully, but these errors were encountered: