mirror of
https://github.com/Relintai/pandemonium_engine_docs.git
synced 2025-01-08 15:09:50 +01:00
78 lines
2.8 KiB
Markdown
78 lines
2.8 KiB
Markdown
|
.. _doc_navigation_using_navigationmaps:
|
||
|
|
||
|
Using NavigationMaps
|
||
|
====================
|
||
|
|
||
|
.. image:: img/nav_maps.png
|
||
|
|
||
|
A NavigationMap is an abstract navigation world on the NavigationServer identified by a NavigationServer :ref:`RID<class_RID>`.
|
||
|
|
||
|
A map can hold and connect a near infinite number of navigation regions with navigation meshes to build the traversable areas of a game world for pathfinding.
|
||
|
|
||
|
A map can be joined by avoidance agents to process collision avoidance between the avoidance agents.
|
||
|
|
||
|
.. note::
|
||
|
|
||
|
Different NavigationMaps are completely isolated from each other but navigation regions
|
||
|
and avoidance agents can switch between different maps once every server synchronization.
|
||
|
|
||
|
Default navigation maps
|
||
|
~~~~~~~~~~~~~~~~~~~~~~~
|
||
|
|
||
|
By default Godot creates a navigation map RID for each :ref:`World2D<class_World2D>` and :ref:`World3D<class_World3D>` of the root viewport.
|
||
|
|
||
|
The 2D default navigation ``map`` can be obtained with ``get_world_2d().get_navigation_map()`` from any :ref:`Node2D<class_Node2D>` inheriting Node.
|
||
|
|
||
|
The 3D default navigation ``map`` can be obtained with ``get_world_3d().get_navigation_map()`` from any :ref:`Node3D<class_Node3D>` inheriting Node.
|
||
|
|
||
|
.. tabs::
|
||
|
.. code-tab:: gdscript GDScript
|
||
|
|
||
|
extends Node2D
|
||
|
|
||
|
var default_2d_navigation_map_rid: RID = get_world_2d().get_navigation_map()
|
||
|
|
||
|
.. tabs::
|
||
|
.. code-tab:: gdscript GDScript
|
||
|
|
||
|
extends Node3D
|
||
|
|
||
|
var default_3d_navigation_map_rid: RID = get_world_3d().get_navigation_map()
|
||
|
|
||
|
Creating new navigation maps
|
||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
|
|
||
|
The NavigationServer can create and support as many navigation maps as are required for specific gameplay.
|
||
|
Additional navigation maps are created and maintained by using the NavigationServer API
|
||
|
directly e.g. to support different avoidance agent or actor locomotion types.
|
||
|
|
||
|
For example uses of different navigation maps see :ref:`doc_navigation_different_actor_types` and :ref:`doc_navigation_different_actor_locomotion`.
|
||
|
|
||
|
Each navigation map synchronizes queued changes to its navigation regions and avoidance agents individually.
|
||
|
A navigation map that has not received changes will consume little to no processing time.
|
||
|
Navigation regions and avoidance agents can only be part of a single navigations map but they can switch maps at any time.
|
||
|
|
||
|
.. note::
|
||
|
|
||
|
A navigation map switch will take effect only after the next NavigationServer synchronization.
|
||
|
|
||
|
.. tabs::
|
||
|
.. code-tab:: gdscript GDScript
|
||
|
|
||
|
extends Node2D
|
||
|
|
||
|
var new_navigation_map: RID = NavigationServer2D.map_create()
|
||
|
NavigationServer2D.map_set_active(true)
|
||
|
|
||
|
.. tabs::
|
||
|
.. code-tab:: gdscript GDScript
|
||
|
|
||
|
extends Node3D
|
||
|
|
||
|
var new_navigation_map: RID = NavigationServer3D.map_create()
|
||
|
NavigationServer3D.map_set_active(true)
|
||
|
|
||
|
.. note::
|
||
|
|
||
|
There is no difference between navigation maps created with the NavigationServer2D API or the NavigationServer3D API.
|