class_nodepath.rst 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. :github_url: hide
  2. .. Generated automatically by doc/tools/make_rst.py in Godot's source tree.
  3. .. DO NOT EDIT THIS FILE, but the NodePath.xml source instead.
  4. .. The source is found in doc/classes or modules/<name>/doc_classes.
  5. .. _class_NodePath:
  6. NodePath
  7. ========
  8. Pre-parsed scene tree path.
  9. Description
  10. -----------
  11. A pre-parsed relative or absolute path in a scene tree, for use with :ref:`Node.get_node<class_Node_method_get_node>` and similar functions. It can reference a node, a resource within a node, or a property of a node or resource. For instance, ``"Path2D/PathFollow2D/Sprite:texture:size"`` would refer to the ``size`` property of the ``texture`` resource on the node named ``"Sprite"`` which is a child of the other named nodes in the path.
  12. You will usually just pass a string to :ref:`Node.get_node<class_Node_method_get_node>` and it will be automatically converted, but you may occasionally want to parse a path ahead of time with ``NodePath`` or the literal syntax ``@"path"``. Exporting a ``NodePath`` variable will give you a node selection widget in the properties panel of the editor, which can often be useful.
  13. A ``NodePath`` is composed of a list of slash-separated node names (like a filesystem path) and an optional colon-separated list of "subnames" which can be resources or properties.
  14. Some examples of NodePaths include the following:
  15. ::
  16. # No leading slash means it is relative to the current node.
  17. @"A" # Immediate child A
  18. @"A/B" # A's child B
  19. @"." # The current node.
  20. @".." # The parent node.
  21. @"../C" # A sibling node C.
  22. # A leading slash means it is absolute from the SceneTree.
  23. @"/root" # Equivalent to get_tree().get_root().
  24. @"/root/Main" # If your main scene's root node were named "Main".
  25. @"/root/MyAutoload" # If you have an autoloaded node or scene.
  26. **Note:** In the editor, ``NodePath`` properties are automatically updated when moving, renaming or deleting a node in the scene tree, but they are never updated at runtime.
  27. Tutorials
  28. ---------
  29. - `2D Role Playing Game Demo <https://godotengine.org/asset-library/asset/520>`__
  30. Methods
  31. -------
  32. +---------------------------------+-----------------------------------------------------------------------------------------------+
  33. | :ref:`NodePath<class_NodePath>` | :ref:`NodePath<class_NodePath_method_NodePath>` **(** :ref:`String<class_String>` from **)** |
  34. +---------------------------------+-----------------------------------------------------------------------------------------------+
  35. | :ref:`NodePath<class_NodePath>` | :ref:`get_as_property_path<class_NodePath_method_get_as_property_path>` **(** **)** |
  36. +---------------------------------+-----------------------------------------------------------------------------------------------+
  37. | :ref:`String<class_String>` | :ref:`get_concatenated_subnames<class_NodePath_method_get_concatenated_subnames>` **(** **)** |
  38. +---------------------------------+-----------------------------------------------------------------------------------------------+
  39. | :ref:`String<class_String>` | :ref:`get_name<class_NodePath_method_get_name>` **(** :ref:`int<class_int>` idx **)** |
  40. +---------------------------------+-----------------------------------------------------------------------------------------------+
  41. | :ref:`int<class_int>` | :ref:`get_name_count<class_NodePath_method_get_name_count>` **(** **)** |
  42. +---------------------------------+-----------------------------------------------------------------------------------------------+
  43. | :ref:`String<class_String>` | :ref:`get_subname<class_NodePath_method_get_subname>` **(** :ref:`int<class_int>` idx **)** |
  44. +---------------------------------+-----------------------------------------------------------------------------------------------+
  45. | :ref:`int<class_int>` | :ref:`get_subname_count<class_NodePath_method_get_subname_count>` **(** **)** |
  46. +---------------------------------+-----------------------------------------------------------------------------------------------+
  47. | :ref:`bool<class_bool>` | :ref:`is_absolute<class_NodePath_method_is_absolute>` **(** **)** |
  48. +---------------------------------+-----------------------------------------------------------------------------------------------+
  49. | :ref:`bool<class_bool>` | :ref:`is_empty<class_NodePath_method_is_empty>` **(** **)** |
  50. +---------------------------------+-----------------------------------------------------------------------------------------------+
  51. Method Descriptions
  52. -------------------
  53. .. _class_NodePath_method_NodePath:
  54. - :ref:`NodePath<class_NodePath>` **NodePath** **(** :ref:`String<class_String>` from **)**
  55. Creates a NodePath from a string, e.g. ``"Path2D/PathFollow2D/Sprite:texture:size"``. A path is absolute if it starts with a slash. Absolute paths are only valid in the global scene tree, not within individual scenes. In a relative path, ``"."`` and ``".."`` indicate the current node and its parent.
  56. The "subnames" optionally included after the path to the target node can point to resources or properties, and can also be nested.
  57. Examples of valid NodePaths (assuming that those nodes exist and have the referenced resources or properties):
  58. ::
  59. # Points to the Sprite node
  60. "Path2D/PathFollow2D/Sprite"
  61. # Points to the Sprite node and its "texture" resource.
  62. # get_node() would retrieve "Sprite", while get_node_and_resource()
  63. # would retrieve both the Sprite node and the "texture" resource.
  64. "Path2D/PathFollow2D/Sprite:texture"
  65. # Points to the Sprite node and its "position" property.
  66. "Path2D/PathFollow2D/Sprite:position"
  67. # Points to the Sprite node and the "x" component of its "position" property.
  68. "Path2D/PathFollow2D/Sprite:position:x"
  69. # Absolute path (from "root")
  70. "/root/Level/Path2D"
  71. ----
  72. .. _class_NodePath_method_get_as_property_path:
  73. - :ref:`NodePath<class_NodePath>` **get_as_property_path** **(** **)**
  74. Returns a node path with a colon character (``:``) prepended, transforming it to a pure property path with no node name (defaults to resolving from the current node).
  75. ::
  76. # This will be parsed as a node path to the "x" property in the "position" node
  77. var node_path = NodePath("position:x")
  78. # This will be parsed as a node path to the "x" component of the "position" property in the current node
  79. var property_path = node_path.get_as_property_path()
  80. print(property_path) # :position:x
  81. ----
  82. .. _class_NodePath_method_get_concatenated_subnames:
  83. - :ref:`String<class_String>` **get_concatenated_subnames** **(** **)**
  84. Returns all subnames concatenated with a colon character (``:``) as separator, i.e. the right side of the first colon in a node path.
  85. ::
  86. var nodepath = NodePath("Path2D/PathFollow2D/Sprite:texture:load_path")
  87. print(nodepath.get_concatenated_subnames()) # texture:load_path
  88. ----
  89. .. _class_NodePath_method_get_name:
  90. - :ref:`String<class_String>` **get_name** **(** :ref:`int<class_int>` idx **)**
  91. Gets the node name indicated by ``idx`` (0 to :ref:`get_name_count<class_NodePath_method_get_name_count>`).
  92. ::
  93. var node_path = NodePath("Path2D/PathFollow2D/Sprite")
  94. print(node_path.get_name(0)) # Path2D
  95. print(node_path.get_name(1)) # PathFollow2D
  96. print(node_path.get_name(2)) # Sprite
  97. ----
  98. .. _class_NodePath_method_get_name_count:
  99. - :ref:`int<class_int>` **get_name_count** **(** **)**
  100. Gets the number of node names which make up the path. Subnames (see :ref:`get_subname_count<class_NodePath_method_get_subname_count>`) are not included.
  101. For example, ``"Path2D/PathFollow2D/Sprite"`` has 3 names.
  102. ----
  103. .. _class_NodePath_method_get_subname:
  104. - :ref:`String<class_String>` **get_subname** **(** :ref:`int<class_int>` idx **)**
  105. Gets the resource or property name indicated by ``idx`` (0 to :ref:`get_subname_count<class_NodePath_method_get_subname_count>`).
  106. ::
  107. var node_path = NodePath("Path2D/PathFollow2D/Sprite:texture:load_path")
  108. print(node_path.get_subname(0)) # texture
  109. print(node_path.get_subname(1)) # load_path
  110. ----
  111. .. _class_NodePath_method_get_subname_count:
  112. - :ref:`int<class_int>` **get_subname_count** **(** **)**
  113. Gets the number of resource or property names ("subnames") in the path. Each subname is listed after a colon character (``:``) in the node path.
  114. For example, ``"Path2D/PathFollow2D/Sprite:texture:load_path"`` has 2 subnames.
  115. ----
  116. .. _class_NodePath_method_is_absolute:
  117. - :ref:`bool<class_bool>` **is_absolute** **(** **)**
  118. Returns ``true`` if the node path is absolute (as opposed to relative), which means that it starts with a slash character (``/``). Absolute node paths can be used to access the root node (``"/root"``) or autoloads (e.g. ``"/global"`` if a "global" autoload was registered).
  119. ----
  120. .. _class_NodePath_method_is_empty:
  121. - :ref:`bool<class_bool>` **is_empty** **(** **)**
  122. Returns ``true`` if the node path is empty.
  123. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  124. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  125. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`