Backported from godot4: Fix cell_height for navigation meshes

Fixes `cell_height` for navigation meshes.
- smix8
180a5cded1
This commit is contained in:
Relintai 2023-09-04 18:34:15 +02:00
parent c326722a65
commit 2f036edcc5
7 changed files with 18 additions and 13 deletions

View File

@ -347,7 +347,7 @@
<return type="float" /> <return type="float" />
<argument index="0" name="map" type="RID" /> <argument index="0" name="map" type="RID" />
<description> <description>
Returns the map cell size. Returns the map cell size used to rasterize the navigation mesh vertices.
</description> </description>
</method> </method>
<method name="map_get_closest_point" qualifiers="const"> <method name="map_get_closest_point" qualifiers="const">
@ -447,7 +447,7 @@
<argument index="0" name="map" type="RID" /> <argument index="0" name="map" type="RID" />
<argument index="1" name="cell_size" type="float" /> <argument index="1" name="cell_size" type="float" />
<description> <description>
Set the map cell size used to weld the navigation mesh polygons. Sets the map cell size used to rasterize the navigation mesh vertices. Must match with the cell size of the used navigation meshes.
</description> </description>
</method> </method>
<method name="map_set_edge_connection_margin"> <method name="map_set_edge_connection_margin">

View File

@ -103,10 +103,10 @@
[b]Note:[/b] While baking, this value will be rounded up to the nearest multiple of [member cell_size]. [b]Note:[/b] While baking, this value will be rounded up to the nearest multiple of [member cell_size].
</member> </member>
<member name="cell_height" type="float" setter="set_cell_height" getter="get_cell_height" default="0.25"> <member name="cell_height" type="float" setter="set_cell_height" getter="get_cell_height" default="0.25">
The Y axis cell size to use for fields. The cell height used to rasterize the navigation mesh vertices on the Y axis. Must match with the cell height on the navigation map.
</member> </member>
<member name="cell_size" type="float" setter="set_cell_size" getter="get_cell_size" default="0.25"> <member name="cell_size" type="float" setter="set_cell_size" getter="get_cell_size" default="0.25">
The XZ plane cell size to use for fields. The cell size used to rasterize the navigation mesh vertices on the XZ plane. Must match with the cell size on the navigation map.
</member> </member>
<member name="detail_sample_distance" type="float" setter="set_detail_sample_distance" getter="get_detail_sample_distance" default="6.0"> <member name="detail_sample_distance" type="float" setter="set_detail_sample_distance" getter="get_detail_sample_distance" default="6.0">
The sampling distance to use when generating the detail mesh, in cell unit. The sampling distance to use when generating the detail mesh, in cell unit.

View File

@ -369,16 +369,16 @@
</method> </method>
<method name="map_get_cell_height" qualifiers="const"> <method name="map_get_cell_height" qualifiers="const">
<return type="float" /> <return type="float" />
<argument index="0" name="map" type="RID" /> <param index="0" name="map" type="RID" />
<description> <description>
Returns the map cell height. Returns the map cell height used to rasterize the navigation mesh vertices on the Y axis.
</description> </description>
</method> </method>
<method name="map_get_cell_size" qualifiers="const"> <method name="map_get_cell_size" qualifiers="const">
<return type="float" /> <return type="float" />
<argument index="0" name="map" type="RID" /> <argument index="0" name="map" type="RID" />
<description> <description>
Returns the map cell size. Returns the map cell size used to rasterize the navigation mesh vertices on the XZ plane.
</description> </description>
</method> </method>
<method name="map_get_closest_point" qualifiers="const"> <method name="map_get_closest_point" qualifiers="const">
@ -495,7 +495,7 @@
<argument index="0" name="map" type="RID" /> <argument index="0" name="map" type="RID" />
<argument index="1" name="cell_height" type="float" /> <argument index="1" name="cell_height" type="float" />
<description> <description>
Set the map cell height used to weld the navigation mesh polygons. Sets the map cell height used to rasterize the navigation mesh vertices on the Y axis. Must match with the cell height of the used navigation meshes.
</description> </description>
</method> </method>
<method name="map_set_cell_size"> <method name="map_set_cell_size">

View File

@ -1352,8 +1352,9 @@ void NavMap::clip_path(const LocalVector<gd::NavigationPoly> &p_navigation_polys
NavMap::NavMap() { NavMap::NavMap() {
up = Vector3(0, 1, 0); up = Vector3(0, 1, 0);
cell_size = 0.25; /// each cell has the following cell_size and cell_height.
cell_height = 0.25; cell_size = 0.25; // Must match ProjectSettings default 3D cell_size and NavigationMesh cell_size.
cell_height = 0.25; // Must match ProjectSettings default 3D cell_height and NavigationMesh cell_height.
edge_connection_margin = 0.25; edge_connection_margin = 0.25;
regenerate_polygons = true; regenerate_polygons = true;
regenerate_links = true; regenerate_links = true;

View File

@ -113,6 +113,10 @@ void NavRegion::update_polygons() {
ERR_PRINT_ONCE(vformat("Navigation map synchronization error. Attempted to update a navigation region with a navigation mesh that uses a `cell_size` of %s while assigned to a navigation map set to a `cell_size` of %s. The cell size for navigation maps can be changed by using the NavigationServer map_set_cell_size() function. The cell size for default navigation maps can also be changed in the ProjectSettings.", double(map->get_cell_size()), double(mesh->get_cell_size()))); ERR_PRINT_ONCE(vformat("Navigation map synchronization error. Attempted to update a navigation region with a navigation mesh that uses a `cell_size` of %s while assigned to a navigation map set to a `cell_size` of %s. The cell size for navigation maps can be changed by using the NavigationServer map_set_cell_size() function. The cell size for default navigation maps can also be changed in the ProjectSettings.", double(map->get_cell_size()), double(mesh->get_cell_size())));
} }
if (!Math::is_equal_approx(double(map->get_cell_height()), double(mesh->get_cell_height()))) {
ERR_PRINT_ONCE("Navigation map synchronization error. Attempted to update a navigation region with a navigation mesh that uses a different `cell_height` than the `cell_height` set on the navigation map.");
}
if (map && Math::rad2deg(map->get_up().angle_to(transform.basis.get_column(1))) >= 90.0f) { if (map && Math::rad2deg(map->get_up().angle_to(transform.basis.get_column(1))) >= 90.0f) {
ERR_PRINT_ONCE(vformat("Navigation map synchronization error. Attempted to update a navigation region with a navigation mesh that uses a `cell_height` of %s while assigned to a navigation map set to a `cell_height` of %s. The cell height for navigation maps can be changed by using the NavigationServer map_set_cell_height() function. The cell height for default navigation maps can also be changed in the ProjectSettings.", double(map->get_cell_height()), double(mesh->get_cell_height()))); ERR_PRINT_ONCE(vformat("Navigation map synchronization error. Attempted to update a navigation region with a navigation mesh that uses a `cell_height` of %s while assigned to a navigation map set to a `cell_height` of %s. The cell height for navigation maps can be changed by using the NavigationServer map_set_cell_height() function. The cell height for default navigation maps can also be changed in the ProjectSettings.", double(map->get_cell_height()), double(mesh->get_cell_height())));
} }

View File

@ -641,8 +641,8 @@ void NavigationMesh::_validate_property(PropertyInfo &property) const {
} }
NavigationMesh::NavigationMesh() { NavigationMesh::NavigationMesh() {
cell_size = 0.25f; cell_size = 0.25f; // Must match ProjectSettings default 3D cell_size and NavigationServer NavMap cell_size.
cell_height = 0.25f; cell_height = 0.25f; // Must match ProjectSettings default 3D cell_height and NavigationServer NavMap cell_height.
agent_height = 1.5f; agent_height = 1.5f;
agent_radius = 0.5f; agent_radius = 0.5f;
agent_max_climb = 0.25f; agent_max_climb = 0.25f;

View File

@ -426,7 +426,7 @@ RID NavigationPolygon::get_rid() const {
NavigationPolygon::NavigationPolygon() { NavigationPolygon::NavigationPolygon() {
agent_radius = 10.0f; agent_radius = 10.0f;
cell_size = 1.0f; cell_size = 1.0f; // Must match ProjectSettings default 2D cell_size.
parsed_geometry_type = PARSED_GEOMETRY_MESH_INSTANCES; parsed_geometry_type = PARSED_GEOMETRY_MESH_INSTANCES;
collision_mask = 0xFFFFFFFF; collision_mask = 0xFFFFFFFF;