2023-06-06 16:52:04 +02:00
<?xml version="1.0" encoding="UTF-8" ?>
2024-02-25 10:26:26 +01:00
<class name= "NavigationPolygon" inherits= "Resource" version= "4.3" >
2023-06-06 16:52:04 +02:00
<brief_description >
A NavigationPolygon is used in pathfinding to describe the traversable area that is safe from collision and other obstructions, assuming an agent's center position at zero radius.
</brief_description>
<description >
A NavigationPolygon is used in pathfinding to describe the traversable area that is safe from collision and other obstructions, assuming an agent's center position at zero radius. The mesh data can be created and baked to polygons with the [NavigationMeshGenerator] by drawing outlines in the Editor, or defining outlines by script, or by parsing source geometry from the [SceneTree]. The mesh data can also be created without outlines and baking by adding the required arrays of vertices and polygon indices more manually and calling [method commit_changes] afterwards.
When doing procedual changes a call to [method commit_changes] is required to apply all the made changes and to synchronize the changes with the [NavigationServer2D].
In scripts there are two more manual ways to create navigation polygons. Either by using the [method add_outline] method and baking with the [NavigationMeshGenerator], or using the methods [method set_vertices] and [method set_polygons] directly.
Using [method add_outline]:
[codeblock]
var new_navigation_polygon = NavigationPolygon.new()
2023-06-10 21:10:45 +02:00
var new_navigation_polygon_outline = PoolVector2Array([Vector2(0, 0), Vector2(0, 50), Vector2(50, 50), Vector2(50, 0)])
2023-06-06 16:52:04 +02:00
new_navigation_polygon.add_outline(new_navigation_polygon_outline)
NavigationMeshGenerator.bake_2d_from_source_geometry_data(new_navigation_polygon, NavigationMeshSourceGeometryData2D.new());
$NavigationRegion2D.navigation_polygon = new_navigation_polygon
[/codeblock]
Using [method add_polygon] and indices of the vertices array.
[codeblock]
var new_navigation_polygon = NavigationPolygon.new()
2023-06-10 21:10:45 +02:00
var new_navigation_polygon_vertices = PoolVector2Array([Vector2(0, 0), Vector2(0, 50), Vector2(50, 50), Vector2(50, 0)])
2023-06-06 16:52:04 +02:00
new_navigation_polygon.vertices = new_navigation_polygon_vertices
2023-06-10 21:10:45 +02:00
var new_navigation_polygon_polygon_indices = PoolIntArray([0, 1, 2, 3])
2023-06-06 16:52:04 +02:00
new_navigation_polygon.add_polygon(new_navigation_polygon_polygon_indices)
new_navigation_polygon.commit_changes()
$NavigationRegion2D.navigation_polygon = new_navigation_polygon
[/codeblock]
</description>
<tutorials >
2023-09-05 12:42:59 +02:00
<link title= "2D Navigation Demo" > https://github.com/Relintai/pandemonium_demo_projects/tree/master/2d/navigation</link>
2023-09-05 09:32:40 +02:00
<link title= "Using NavigationMeshes" > $DOCS_URL/tutorials/navigation/navigation_using_navigationmeshes.md</link>
2023-06-06 16:52:04 +02:00
</tutorials>
<methods >
<method name= "add_outline" >
<return type= "void" />
<argument index= "0" name= "outline" type= "PoolVector2Array" />
<description >
Appends a [PoolVector2Array] that contains the vertices of an outline to the internal array that contains all the outlines. You have to call [method make_polygons_from_outlines] in order for this array to be converted to polygons that the engine will use.
</description>
</method>
<method name= "add_outline_at_index" >
<return type= "void" />
<argument index= "0" name= "outline" type= "PoolVector2Array" />
<argument index= "1" name= "index" type= "int" />
<description >
Adds a [PoolVector2Array] that contains the vertices of an outline to the internal array that contains all the outlines at a fixed position. You have to call [method make_polygons_from_outlines] in order for this array to be converted to polygons that the engine will use.
</description>
</method>
<method name= "add_polygon" >
<return type= "void" />
<argument index= "0" name= "polygon" type= "PoolIntArray" />
<description >
Adds a polygon using the indices of the vertices you get when calling [method get_vertices].
</description>
</method>
<method name= "clear_outlines" >
<return type= "void" />
<description >
Clears the array of the outlines, but it doesn't clear the vertices and the polygons that were created by them.
</description>
</method>
<method name= "clear_polygons" >
<return type= "void" />
<description >
Clears the array of polygons, but it doesn't clear the array of outlines and vertices.
</description>
</method>
2023-06-13 18:19:02 +02:00
<method name= "commit_changes" >
<return type= "void" />
<description >
Applies all changes to vertices and polygons and synchronizes with the [NavigationServer2D].
</description>
</method>
<method name= "get_baked_outlines" qualifiers= "const" >
<return type= "Array" />
<description >
Returns the array of baked outlines. The baked outlines are the result of a finished [NavigationMeshGenerator] baking process and primarily used for debugging purposes.
</description>
</method>
<method name= "get_collision_mask_value" qualifiers= "const" >
<return type= "bool" />
<argument index= "0" name= "layer_number" type= "int" />
<description >
Returns whether or not the specified layer of the [member geometry_collision_mask] is enabled, given a [param layer_number] between 1 and 32.
</description>
</method>
<method name= "get_navigation_mesh" >
2023-06-06 16:52:04 +02:00
<return type= "NavigationMesh" />
<description >
</description>
</method>
<method name= "get_outline" qualifiers= "const" >
<return type= "PoolVector2Array" />
<argument index= "0" name= "idx" type= "int" />
<description >
Returns a [PoolVector2Array] containing the vertices of an outline that was created in the editor or by script.
</description>
</method>
<method name= "get_outline_count" qualifiers= "const" >
<return type= "int" />
<description >
Returns the number of outlines that were created in the editor or by script.
</description>
</method>
2023-06-13 18:19:02 +02:00
<method name= "get_outlines" qualifiers= "const" >
<return type= "Array" />
<description >
</description>
</method>
2023-06-06 16:52:04 +02:00
<method name= "get_polygon" >
<return type= "PoolIntArray" />
<argument index= "0" name= "idx" type= "int" />
<description >
Returns a [PoolIntArray] containing the indices of the vertices of a created polygon.
</description>
</method>
<method name= "get_polygon_count" qualifiers= "const" >
<return type= "int" />
<description >
Returns the number of polygons.
</description>
</method>
<method name= "get_polygons" qualifiers= "const" >
<return type= "Array" />
<description >
Returns the array of polygons used by the internal navigation mesh. Each polygon array consists of the indices for the vertices that make the polygon.
</description>
</method>
<method name= "get_vertices" qualifiers= "const" >
<return type= "PoolVector2Array" />
<description >
Returns a [PoolVector2Array] containing all the vertices being used to create the polygons.
</description>
</method>
<method name= "make_polygons_from_outlines" >
<return type= "void" />
<description >
Creates polygons from the outlines added in the editor or by script.
</description>
</method>
<method name= "remove_outline" >
<return type= "void" />
<argument index= "0" name= "idx" type= "int" />
<description >
Removes an outline created in the editor or by script.
</description>
</method>
2023-06-13 18:19:02 +02:00
<method name= "set_baked_outlines" >
<return type= "void" />
<argument index= "0" name= "outlines" type= "Array" />
<description >
Sets the array of baked outlines. The baked outlines are the result of a finished [NavigationMeshGenerator] baking process and primarily used for debugging purposes.
</description>
</method>
<method name= "set_collision_mask_value" >
<return type= "void" />
<argument index= "0" name= "layer_number" type= "int" />
<argument index= "1" name= "value" type= "bool" />
<description >
</description>
</method>
2023-06-06 16:52:04 +02:00
<method name= "set_outline" >
<return type= "void" />
<argument index= "0" name= "idx" type= "int" />
<argument index= "1" name= "outline" type= "PoolVector2Array" />
<description >
Changes an outline created in the editor or by script.
</description>
</method>
2023-06-13 18:19:02 +02:00
<method name= "set_outlines" >
2023-06-06 16:52:04 +02:00
<return type= "void" />
2023-06-13 18:19:02 +02:00
<argument index= "0" name= "outlines" type= "Array" />
2023-06-06 16:52:04 +02:00
<description >
2023-06-13 18:19:02 +02:00
Sets the outline arrays. The outlines need to be baked to actual navigation mesh polygons by using the [NavigationMeshGenerator].
2023-06-06 16:52:04 +02:00
</description>
</method>
2023-06-13 18:19:02 +02:00
<method name= "set_polygons" >
2023-06-06 16:52:04 +02:00
<return type= "void" />
2023-06-13 18:19:02 +02:00
<argument index= "0" name= "polygons" type= "Array" />
2023-06-06 16:52:04 +02:00
<description >
2023-06-13 18:19:02 +02:00
Sets the navigation mesh polygons. Each polygon array needs to consist of the indices for the vertices that make the polygon.
2023-06-06 16:52:04 +02:00
</description>
</method>
2023-06-13 18:19:02 +02:00
<method name= "set_vertices" >
<return type= "void" />
<argument index= "0" name= "vertices" type= "PoolVector2Array" />
2023-06-06 16:52:04 +02:00
<description >
2023-06-13 18:19:02 +02:00
Sets the vertices that need to be indexed with the [method add_polygon] or [method set_polygons] methods. When finished changing the navigation polygon call [method commit_changes] in order to synchronize the changes with the [Navigation2DServer].
2023-06-06 16:52:04 +02:00
</description>
</method>
</methods>
<members >
<member name= "agent_radius" type= "float" setter= "set_agent_radius" getter= "get_agent_radius" default= "10.0" >
The distance to erode/shrink the traversable area from obstructions when baking polygons.
</member>
2023-09-10 08:42:24 +02:00
<member name= "cell_size" type= "float" setter= "set_cell_size" getter= "get_cell_size" default= "1.0" >
The cell size used to rasterize the navigation mesh vertices. Must match with the cell size on the navigation map.
</member>
2023-06-06 16:52:04 +02:00
<member name= "geometry_collision_mask" type= "int" setter= "set_collision_mask" getter= "get_collision_mask" default= "4294967295" >
The physics layers to scan for static colliders. Only used when [member geometry_parsed_geometry_type] is [constant PARSED_GEOMETRY_STATIC_COLLIDERS] or [constant PARSED_GEOMETRY_BOTH].
</member>
<member name= "geometry_parsed_geometry_type" type= "int" setter= "set_parsed_geometry_type" getter= "get_parsed_geometry_type" enum= "NavigationPolygon.ParsedGeometryType" default= "0" >
Determines which type of nodes will be parsed as geometry. See [enum ParsedGeometryType] for possible values.
</member>
<member name= "geometry_source_geometry_mode" type= "int" setter= "set_source_geometry_mode" getter= "get_source_geometry_mode" enum= "NavigationPolygon.SourceGeometryMode" default= "0" >
The source of the geometry used when baking. See [enum SourceGeometryMode] for possible values.
</member>
2023-06-13 18:19:02 +02:00
<member name= "geometry_source_group_name" type= "StringName" setter= "set_source_group_name" getter= "get_source_group_name" default= "@"navigation_polygon_source_group"" >
2023-06-06 16:52:04 +02:00
The name of the group to scan for geometry. Only used when [member geometry_source_geometry_mode] is [constant SOURCE_GEOMETRY_GROUPS_WITH_CHILDREN] or [constant SOURCE_GEOMETRY_GROUPS_EXPLICIT].
</member>
<member name= "offsetting_jointype" type= "int" setter= "set_offsetting_jointype" getter= "get_offsetting_jointype" enum= "NavigationPolygon.OffsettingJoinType" default= "2" >
The [enum OffsettingJoinType] used for joins when offsetting the bake polygons by [member agent_radius].
</member>
<member name= "polygon_bake_fillrule" type= "int" setter= "set_polygon_bake_fillrule" getter= "get_polygon_bake_fillrule" enum= "NavigationPolygon.PolygonFillRule" default= "0" >
Filling rule for baking polygons that defines in complex polygons which polygon sub-regions will be considered inside a given polygon, and which sub-regions will not, aka what is a hole.
</member>
</members>
<constants >
<constant name= "PARSED_GEOMETRY_MESH_INSTANCES" value= "0" enum= "ParsedGeometryType" >
Parses mesh instances and other visual shapes as geometry. This includes [MeshInstance2D], [MultiMeshInstance2D], [Polygon2D], and [TileMap] (first TileMapLayer only) nodes.
</constant>
<constant name= "PARSED_GEOMETRY_STATIC_COLLIDERS" value= "1" enum= "ParsedGeometryType" >
Parses [StaticBody2D], and [TileMap] (first TileMapLayer only) colliders as geometry. The collider should be in any of the layers specified by [member geometry_collision_mask].
</constant>
<constant name= "PARSED_GEOMETRY_BOTH" value= "2" enum= "ParsedGeometryType" >
Both [constant PARSED_GEOMETRY_MESH_INSTANCES] and [constant PARSED_GEOMETRY_STATIC_COLLIDERS].
</constant>
<constant name= "PARSED_GEOMETRY_MAX" value= "3" enum= "ParsedGeometryType" >
Represents the size of the [enum ParsedGeometryType] enum.
</constant>
<constant name= "SOURCE_GEOMETRY_ROOT_NODE_CHILDREN" value= "0" enum= "SourceGeometryMode" >
Scans the child nodes of the root node recursively for geometry.
</constant>
<constant name= "SOURCE_GEOMETRY_GROUPS_WITH_CHILDREN" value= "1" enum= "SourceGeometryMode" >
Scans nodes in a group and their child nodes recursively for geometry. The group is specified by [member geometry_source_group_name].
</constant>
<constant name= "SOURCE_GEOMETRY_GROUPS_EXPLICIT" value= "2" enum= "SourceGeometryMode" >
Uses nodes in a group for geometry. The group is specified by [member geometry_source_group_name].
</constant>
<constant name= "SOURCE_GEOMETRY_MAX" value= "3" enum= "SourceGeometryMode" >
Represents the size of the [enum SourceGeometryMode] enum.
</constant>
<constant name= "POLYGON_FILLRULE_EVENODD" value= "0" enum= "PolygonFillRule" >
Only odd numbered sub-regions are filled
</constant>
<constant name= "POLYGON_FILLRULE_NONZERO" value= "1" enum= "PolygonFillRule" >
Only non-zero sub-regions are filled
</constant>
<constant name= "POLYGON_FILLRULE_POSITIVE" value= "2" enum= "PolygonFillRule" >
Only sub-regions with winding counts greater zero are filled.
</constant>
<constant name= "POLYGON_FILLRULE_NEGATIVE" value= "3" enum= "PolygonFillRule" >
Only sub-regions with winding counts smaller zero are filled.
</constant>
<constant name= "POLYGON_FILLRULE_MAX" value= "4" enum= "PolygonFillRule" >
Represents the size of the [enum PolygonFillRule] enum.
</constant>
<constant name= "OFFSETTING_JOINTYPE_SQUARE" value= "0" enum= "OffsettingJoinType" >
Squaring is applied uniformally at all joins where the internal join angle is less that 90 degrees. The squared edge will be at exactly the offset distance from the join vertex.
</constant>
<constant name= "OFFSETTING_JOINTYPE_ROUND" value= "1" enum= "OffsettingJoinType" >
Rounding is applied to all joins that have convex external angles and the exact offset distance from the join vertex is maintained.
</constant>
<constant name= "OFFSETTING_JOINTYPE_MITER" value= "2" enum= "OffsettingJoinType" >
Creates mitered joins such that the line of junction bisects the angle. To avoid narrow angled joins producing excessively long and narrow spikes mitered joins are automatically squared when they exceed a given maximum miter distance relative to the offset distance.
</constant>
<constant name= "OFFSETTING_JOINTYPE_MAX" value= "3" enum= "OffsettingJoinType" >
Represents the size of the [enum OffsettingJoinType] enum.
</constant>
</constants>
</class>