mirror of
https://github.com/Relintai/pandemonium_engine_docs.git
synced 2025-01-23 15:17:21 +01:00
54 lines
3.1 KiB
Markdown
54 lines
3.1 KiB
Markdown
|
.. _doc_navigation_using_navigationlinks:
|
||
|
|
||
|
Using NavigationLinks
|
||
|
=====================
|
||
|
|
||
|
.. image:: img/nav_navmesh_links.png
|
||
|
|
||
|
NavigationLinks are used to connect navigation mesh polygons from :ref:`NavigationRegion2D<class_NavigationRegion2D>`
|
||
|
and :ref:`NavigationRegion3D<class_NavigationRegion3D>` over arbitrary distances for pathfinding.
|
||
|
|
||
|
NavigationLinks are also used to consider movement shortcuts in pathfinding available through
|
||
|
interacting with gameplay objects e.g. ladders, jump pads or teleports.
|
||
|
|
||
|
2D and 3D versions of NavigationJumplinks nodes are available as
|
||
|
:ref:`NavigationLink2D<class_NavigationLink2D>` and
|
||
|
:ref:`NavigationLink3D<class_NavigationLink3D>` respectively.
|
||
|
|
||
|
Different NavigationRegions can connect their navigation meshes without the need for a NavigationLink
|
||
|
as long as they are within navigation map ``edge_connection_margin`` and have compatible ``navigation_layers``.
|
||
|
As soon as the distance becomes too large, building valid connections becomes a problem - a problem that NavigationLinks can solve.
|
||
|
|
||
|
See :ref:`doc_navigation_using_navigationregions` to learn more about the use of navigation regions.
|
||
|
See :ref:`doc_navigation_connecting_navmesh` to learn more about how to connect navigation meshes.
|
||
|
|
||
|
.. image:: img/nav_link_properties.png
|
||
|
|
||
|
NavigationLinks share many properties with NavigationRegions like ``navigation_layers``.
|
||
|
NavigationLinks add a single connection between two positions over an arbitrary distance
|
||
|
compared to NavigationRegions that add a more local traversable area with a navigation mesh resource.
|
||
|
|
||
|
NavigationLinks have a ``start_position`` and ``end_position`` and can go in both directions when ``bidirectional`` is enabled.
|
||
|
When placed a navigationlink connects the navigation mesh polygons closest to its ``start_position`` and ``end_position`` within search radius for pathfinding.
|
||
|
|
||
|
The polygon search radius can be configured globally in the ProjectSettings under ``navigation/2d_or_3d/default_link_connection_radius``
|
||
|
or set for each navigation ``map`` individually using the ``NavigationServer.map_set_link_connection_radius()`` function.
|
||
|
|
||
|
Both ``start_position`` and ``end_position`` have debug markers in the Editor.
|
||
|
The visible radius of a position shows the polygon search radius.
|
||
|
All navigation mesh polygons inside are compared and the closest is picked for the edge connection.
|
||
|
If no valid polygon is found within the search radius the navigation link gets disabled.
|
||
|
|
||
|
.. image:: img/nav_link_debug_visuals.png
|
||
|
|
||
|
The link debug visuals can be changed in the Editor :ref:`ProjectSettings<class_ProjectSettings>` under ``debug/shapes/navigation``.
|
||
|
The visibility of the debug can also be controlled in the Editor 3D Viewport gizmo menu.
|
||
|
|
||
|
.. note::
|
||
|
|
||
|
NavigationLinks do not move agents between the two link positions by themselves.
|
||
|
|
||
|
A navigation link does not provide any automated movement through the link. Instead, when
|
||
|
an agent reaches the position of a link, game code needs to react (e.g. through area triggers) and provide means for the agent
|
||
|
to move through the link to end up at the links other position (e.g. through teleport or animation) to continue along the path.
|