class_navigationpolygon.rst 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. :github_url: hide
  2. .. Generated automatically by doc/tools/makerst.py in Godot's source tree.
  3. .. DO NOT EDIT THIS FILE, but the NavigationPolygon.xml source instead.
  4. .. The source is found in doc/classes or modules/<name>/doc_classes.
  5. .. _class_NavigationPolygon:
  6. NavigationPolygon
  7. =================
  8. **Inherits:** :ref:`Resource<class_Resource>` **<** :ref:`Reference<class_Reference>` **<** :ref:`Object<class_Object>`
  9. A node that has methods to draw outlines or use indices of vertices to create navigation polygons.
  10. Description
  11. -----------
  12. There are two ways to create polygons. Either by using the :ref:`add_outline<class_NavigationPolygon_method_add_outline>` method, or using the :ref:`add_polygon<class_NavigationPolygon_method_add_polygon>` method.
  13. Using :ref:`add_outline<class_NavigationPolygon_method_add_outline>`:
  14. ::
  15. var polygon = NavigationPolygon.new()
  16. var outline = PoolVector2Array([Vector2(0, 0), Vector2(0, 50), Vector2(50, 50), Vector2(50, 0)])
  17. polygon.add_outline(outline)
  18. polygon.make_polygons_from_outlines()
  19. $NavigationPolygonInstance.navpoly = polygon
  20. Using :ref:`add_polygon<class_NavigationPolygon_method_add_polygon>` and indices of the vertices array.
  21. ::
  22. var polygon = NavigationPolygon.new()
  23. var vertices = PoolVector2Array([Vector2(0, 0), Vector2(0, 50), Vector2(50, 50), Vector2(50, 0)])
  24. polygon.set_vertices(vertices)
  25. var indices = PoolIntArray(0, 3, 1)
  26. polygon.add_polygon(indices)
  27. $NavigationPolygonInstance.navpoly = polygon
  28. Methods
  29. -------
  30. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  31. | void | :ref:`add_outline<class_NavigationPolygon_method_add_outline>` **(** :ref:`PoolVector2Array<class_PoolVector2Array>` outline **)** |
  32. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  33. | void | :ref:`add_outline_at_index<class_NavigationPolygon_method_add_outline_at_index>` **(** :ref:`PoolVector2Array<class_PoolVector2Array>` outline, :ref:`int<class_int>` index **)** |
  34. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  35. | void | :ref:`add_polygon<class_NavigationPolygon_method_add_polygon>` **(** :ref:`PoolIntArray<class_PoolIntArray>` polygon **)** |
  36. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  37. | void | :ref:`clear_outlines<class_NavigationPolygon_method_clear_outlines>` **(** **)** |
  38. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  39. | void | :ref:`clear_polygons<class_NavigationPolygon_method_clear_polygons>` **(** **)** |
  40. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  41. | :ref:`PoolVector2Array<class_PoolVector2Array>` | :ref:`get_outline<class_NavigationPolygon_method_get_outline>` **(** :ref:`int<class_int>` idx **)** |const| |
  42. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  43. | :ref:`int<class_int>` | :ref:`get_outline_count<class_NavigationPolygon_method_get_outline_count>` **(** **)** |const| |
  44. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  45. | :ref:`PoolIntArray<class_PoolIntArray>` | :ref:`get_polygon<class_NavigationPolygon_method_get_polygon>` **(** :ref:`int<class_int>` idx **)** |
  46. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  47. | :ref:`int<class_int>` | :ref:`get_polygon_count<class_NavigationPolygon_method_get_polygon_count>` **(** **)** |const| |
  48. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  49. | :ref:`PoolVector2Array<class_PoolVector2Array>` | :ref:`get_vertices<class_NavigationPolygon_method_get_vertices>` **(** **)** |const| |
  50. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  51. | void | :ref:`make_polygons_from_outlines<class_NavigationPolygon_method_make_polygons_from_outlines>` **(** **)** |
  52. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  53. | void | :ref:`remove_outline<class_NavigationPolygon_method_remove_outline>` **(** :ref:`int<class_int>` idx **)** |
  54. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  55. | void | :ref:`set_outline<class_NavigationPolygon_method_set_outline>` **(** :ref:`int<class_int>` idx, :ref:`PoolVector2Array<class_PoolVector2Array>` outline **)** |
  56. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  57. | void | :ref:`set_vertices<class_NavigationPolygon_method_set_vertices>` **(** :ref:`PoolVector2Array<class_PoolVector2Array>` vertices **)** |
  58. +-------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  59. Method Descriptions
  60. -------------------
  61. .. _class_NavigationPolygon_method_add_outline:
  62. - void **add_outline** **(** :ref:`PoolVector2Array<class_PoolVector2Array>` outline **)**
  63. Appends a :ref:`PoolVector2Array<class_PoolVector2Array>` that contains the vertices of an outline to the internal array that contains all the outlines. You have to call :ref:`make_polygons_from_outlines<class_NavigationPolygon_method_make_polygons_from_outlines>` in order for this array to be converted to polygons that the engine will use.
  64. ----
  65. .. _class_NavigationPolygon_method_add_outline_at_index:
  66. - void **add_outline_at_index** **(** :ref:`PoolVector2Array<class_PoolVector2Array>` outline, :ref:`int<class_int>` index **)**
  67. Adds a :ref:`PoolVector2Array<class_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 :ref:`make_polygons_from_outlines<class_NavigationPolygon_method_make_polygons_from_outlines>` in order for this array to be converted to polygons that the engine will use.
  68. ----
  69. .. _class_NavigationPolygon_method_add_polygon:
  70. - void **add_polygon** **(** :ref:`PoolIntArray<class_PoolIntArray>` polygon **)**
  71. Adds a polygon using the indices of the vertices you get when calling :ref:`get_vertices<class_NavigationPolygon_method_get_vertices>`.
  72. ----
  73. .. _class_NavigationPolygon_method_clear_outlines:
  74. - void **clear_outlines** **(** **)**
  75. Clears the array of the outlines, but it doesn't clear the vertices and the polygons that were created by them.
  76. ----
  77. .. _class_NavigationPolygon_method_clear_polygons:
  78. - void **clear_polygons** **(** **)**
  79. Clears the array of polygons, but it doesn't clear the array of outlines and vertices.
  80. ----
  81. .. _class_NavigationPolygon_method_get_outline:
  82. - :ref:`PoolVector2Array<class_PoolVector2Array>` **get_outline** **(** :ref:`int<class_int>` idx **)** |const|
  83. Returns a :ref:`PoolVector2Array<class_PoolVector2Array>` containing the vertices of an outline that was created in the editor or by script.
  84. ----
  85. .. _class_NavigationPolygon_method_get_outline_count:
  86. - :ref:`int<class_int>` **get_outline_count** **(** **)** |const|
  87. Returns the number of outlines that were created in the editor or by script.
  88. ----
  89. .. _class_NavigationPolygon_method_get_polygon:
  90. - :ref:`PoolIntArray<class_PoolIntArray>` **get_polygon** **(** :ref:`int<class_int>` idx **)**
  91. Returns a :ref:`PoolIntArray<class_PoolIntArray>` containing the indices of the vertices of a created polygon.
  92. ----
  93. .. _class_NavigationPolygon_method_get_polygon_count:
  94. - :ref:`int<class_int>` **get_polygon_count** **(** **)** |const|
  95. Returns the count of all polygons.
  96. ----
  97. .. _class_NavigationPolygon_method_get_vertices:
  98. - :ref:`PoolVector2Array<class_PoolVector2Array>` **get_vertices** **(** **)** |const|
  99. Returns a :ref:`PoolVector2Array<class_PoolVector2Array>` containing all the vertices being used to create the polygons.
  100. ----
  101. .. _class_NavigationPolygon_method_make_polygons_from_outlines:
  102. - void **make_polygons_from_outlines** **(** **)**
  103. Creates polygons from the outlines added in the editor or by script.
  104. ----
  105. .. _class_NavigationPolygon_method_remove_outline:
  106. - void **remove_outline** **(** :ref:`int<class_int>` idx **)**
  107. Removes an outline created in the editor or by script. You have to call :ref:`make_polygons_from_outlines<class_NavigationPolygon_method_make_polygons_from_outlines>` for the polygons to update.
  108. ----
  109. .. _class_NavigationPolygon_method_set_outline:
  110. - void **set_outline** **(** :ref:`int<class_int>` idx, :ref:`PoolVector2Array<class_PoolVector2Array>` outline **)**
  111. Changes an outline created in the editor or by script. You have to call :ref:`make_polygons_from_outlines<class_NavigationPolygon_method_make_polygons_from_outlines>` for the polygons to update.
  112. ----
  113. .. _class_NavigationPolygon_method_set_vertices:
  114. - void **set_vertices** **(** :ref:`PoolVector2Array<class_PoolVector2Array>` vertices **)**
  115. Sets the vertices that can be then indexed to create polygons with the :ref:`add_polygon<class_NavigationPolygon_method_add_polygon>` method.
  116. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  117. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  118. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`