123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929 |
- :github_url: hide
- .. DO NOT EDIT THIS FILE!!!
- .. Generated automatically from Godot engine sources.
- .. Generator: https://github.com/godotengine/godot/tree/master/doc/tools/make_rst.py.
- .. XML source: https://github.com/godotengine/godot/tree/master/modules/gltf/doc_classes/GLTFState.xml.
- .. _class_GLTFState:
- GLTFState
- =========
- **Inherits:** :ref:`Resource<class_Resource>` **<** :ref:`RefCounted<class_RefCounted>` **<** :ref:`Object<class_Object>`
- Represents all data of a GLTF file.
- .. rst-class:: classref-introduction-group
- Description
- -----------
- Contains all nodes and resources of a GLTF file. This is used by :ref:`GLTFDocument<class_GLTFDocument>` as data storage, which allows :ref:`GLTFDocument<class_GLTFDocument>` and all :ref:`GLTFDocumentExtension<class_GLTFDocumentExtension>` classes to remain stateless.
- GLTFState can be populated by :ref:`GLTFDocument<class_GLTFDocument>` reading a file or by converting a Godot scene. Then the data can either be used to create a Godot scene or save to a GLTF file. The code that converts to/from a Godot scene can be intercepted at arbitrary points by :ref:`GLTFDocumentExtension<class_GLTFDocumentExtension>` classes. This allows for custom data to be stored in the GLTF file or for custom data to be converted to/from Godot nodes.
- .. rst-class:: classref-introduction-group
- Tutorials
- ---------
- - :doc:`Runtime file loading and saving <../tutorials/io/runtime_file_loading_and_saving>`
- - `GLTF asset header schema <https://github.com/KhronosGroup/glTF/blob/main/specification/2.0/schema/asset.schema.json">`__
- .. rst-class:: classref-reftable-group
- Properties
- ----------
- .. table::
- :widths: auto
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- | :ref:`String<class_String>` | :ref:`base_path<class_GLTFState_property_base_path>` | ``""`` |
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- | :ref:`PackedByteArray[]<class_PackedByteArray>` | :ref:`buffers<class_GLTFState_property_buffers>` | ``[]`` |
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- | :ref:`String<class_String>` | :ref:`copyright<class_GLTFState_property_copyright>` | ``""`` |
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- | :ref:`bool<class_bool>` | :ref:`create_animations<class_GLTFState_property_create_animations>` | ``true`` |
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- | :ref:`String<class_String>` | :ref:`filename<class_GLTFState_property_filename>` | ``""`` |
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- | :ref:`PackedByteArray<class_PackedByteArray>` | :ref:`glb_data<class_GLTFState_property_glb_data>` | ``PackedByteArray()`` |
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- | :ref:`Dictionary<class_Dictionary>` | :ref:`json<class_GLTFState_property_json>` | ``{}`` |
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- | :ref:`int<class_int>` | :ref:`major_version<class_GLTFState_property_major_version>` | ``0`` |
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- | :ref:`int<class_int>` | :ref:`minor_version<class_GLTFState_property_minor_version>` | ``0`` |
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- | :ref:`PackedInt32Array<class_PackedInt32Array>` | :ref:`root_nodes<class_GLTFState_property_root_nodes>` | ``PackedInt32Array()`` |
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- | :ref:`String<class_String>` | :ref:`scene_name<class_GLTFState_property_scene_name>` | ``""`` |
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- | :ref:`bool<class_bool>` | :ref:`use_named_skin_binds<class_GLTFState_property_use_named_skin_binds>` | ``false`` |
- +-------------------------------------------------+----------------------------------------------------------------------------+------------------------+
- .. rst-class:: classref-reftable-group
- Methods
- -------
- .. table::
- :widths: auto
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`add_used_extension<class_GLTFState_method_add_used_extension>` **(** :ref:`String<class_String>` extension_name, :ref:`bool<class_bool>` required **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`GLTFAccessor[]<class_GLTFAccessor>` | :ref:`get_accessors<class_GLTFState_method_get_accessors>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`Variant<class_Variant>` | :ref:`get_additional_data<class_GLTFState_method_get_additional_data>` **(** :ref:`StringName<class_StringName>` extension_name **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`AnimationPlayer<class_AnimationPlayer>` | :ref:`get_animation_player<class_GLTFState_method_get_animation_player>` **(** :ref:`int<class_int>` idx **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`int<class_int>` | :ref:`get_animation_players_count<class_GLTFState_method_get_animation_players_count>` **(** :ref:`int<class_int>` idx **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`GLTFAnimation[]<class_GLTFAnimation>` | :ref:`get_animations<class_GLTFState_method_get_animations>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`GLTFBufferView[]<class_GLTFBufferView>` | :ref:`get_buffer_views<class_GLTFState_method_get_buffer_views>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`GLTFCamera[]<class_GLTFCamera>` | :ref:`get_cameras<class_GLTFState_method_get_cameras>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`int<class_int>` | :ref:`get_handle_binary_image<class_GLTFState_method_get_handle_binary_image>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`Texture2D[]<class_Texture2D>` | :ref:`get_images<class_GLTFState_method_get_images>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`GLTFLight[]<class_GLTFLight>` | :ref:`get_lights<class_GLTFState_method_get_lights>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`Material[]<class_Material>` | :ref:`get_materials<class_GLTFState_method_get_materials>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`GLTFMesh[]<class_GLTFMesh>` | :ref:`get_meshes<class_GLTFState_method_get_meshes>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`int<class_int>` | :ref:`get_node_index<class_GLTFState_method_get_node_index>` **(** :ref:`Node<class_Node>` scene_node **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`GLTFNode[]<class_GLTFNode>` | :ref:`get_nodes<class_GLTFState_method_get_nodes>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`Node<class_Node>` | :ref:`get_scene_node<class_GLTFState_method_get_scene_node>` **(** :ref:`int<class_int>` idx **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`GLTFSkeleton[]<class_GLTFSkeleton>` | :ref:`get_skeletons<class_GLTFState_method_get_skeletons>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`GLTFSkin[]<class_GLTFSkin>` | :ref:`get_skins<class_GLTFState_method_get_skins>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`GLTFTextureSampler[]<class_GLTFTextureSampler>` | :ref:`get_texture_samplers<class_GLTFState_method_get_texture_samplers>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`GLTFTexture[]<class_GLTFTexture>` | :ref:`get_textures<class_GLTFState_method_get_textures>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`String[]<class_String>` | :ref:`get_unique_animation_names<class_GLTFState_method_get_unique_animation_names>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`String[]<class_String>` | :ref:`get_unique_names<class_GLTFState_method_get_unique_names>` **(** **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_accessors<class_GLTFState_method_set_accessors>` **(** :ref:`GLTFAccessor[]<class_GLTFAccessor>` accessors **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_additional_data<class_GLTFState_method_set_additional_data>` **(** :ref:`StringName<class_StringName>` extension_name, :ref:`Variant<class_Variant>` additional_data **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_animations<class_GLTFState_method_set_animations>` **(** :ref:`GLTFAnimation[]<class_GLTFAnimation>` animations **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_buffer_views<class_GLTFState_method_set_buffer_views>` **(** :ref:`GLTFBufferView[]<class_GLTFBufferView>` buffer_views **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_cameras<class_GLTFState_method_set_cameras>` **(** :ref:`GLTFCamera[]<class_GLTFCamera>` cameras **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_handle_binary_image<class_GLTFState_method_set_handle_binary_image>` **(** :ref:`int<class_int>` method **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_images<class_GLTFState_method_set_images>` **(** :ref:`Texture2D[]<class_Texture2D>` images **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_lights<class_GLTFState_method_set_lights>` **(** :ref:`GLTFLight[]<class_GLTFLight>` lights **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_materials<class_GLTFState_method_set_materials>` **(** :ref:`Material[]<class_Material>` materials **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_meshes<class_GLTFState_method_set_meshes>` **(** :ref:`GLTFMesh[]<class_GLTFMesh>` meshes **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_nodes<class_GLTFState_method_set_nodes>` **(** :ref:`GLTFNode[]<class_GLTFNode>` nodes **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_skeletons<class_GLTFState_method_set_skeletons>` **(** :ref:`GLTFSkeleton[]<class_GLTFSkeleton>` skeletons **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_skins<class_GLTFState_method_set_skins>` **(** :ref:`GLTFSkin[]<class_GLTFSkin>` skins **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_texture_samplers<class_GLTFState_method_set_texture_samplers>` **(** :ref:`GLTFTextureSampler[]<class_GLTFTextureSampler>` texture_samplers **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_textures<class_GLTFState_method_set_textures>` **(** :ref:`GLTFTexture[]<class_GLTFTexture>` textures **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_unique_animation_names<class_GLTFState_method_set_unique_animation_names>` **(** :ref:`String[]<class_String>` unique_animation_names **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`set_unique_names<class_GLTFState_method_set_unique_names>` **(** :ref:`String[]<class_String>` unique_names **)** |
- +-------------------------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Constants
- ---------
- .. _class_GLTFState_constant_HANDLE_BINARY_DISCARD_TEXTURES:
- .. rst-class:: classref-constant
- **HANDLE_BINARY_DISCARD_TEXTURES** = ``0``
- Discards all embedded textures and uses untextured materials.
- .. _class_GLTFState_constant_HANDLE_BINARY_EXTRACT_TEXTURES:
- .. rst-class:: classref-constant
- **HANDLE_BINARY_EXTRACT_TEXTURES** = ``1``
- Extracts embedded textures to be reimported and compressed. Editor only. Acts as uncompressed at runtime.
- .. _class_GLTFState_constant_HANDLE_BINARY_EMBED_AS_BASISU:
- .. rst-class:: classref-constant
- **HANDLE_BINARY_EMBED_AS_BASISU** = ``2``
- Embeds textures VRAM compressed with Basis Universal into the generated scene.
- .. _class_GLTFState_constant_HANDLE_BINARY_EMBED_AS_UNCOMPRESSED:
- .. rst-class:: classref-constant
- **HANDLE_BINARY_EMBED_AS_UNCOMPRESSED** = ``3``
- Embeds textures compressed losslessly into the generated scene, matching old behavior.
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Property Descriptions
- ---------------------
- .. _class_GLTFState_property_base_path:
- .. rst-class:: classref-property
- :ref:`String<class_String>` **base_path** = ``""``
- .. rst-class:: classref-property-setget
- - void **set_base_path** **(** :ref:`String<class_String>` value **)**
- - :ref:`String<class_String>` **get_base_path** **(** **)**
- The folder path associated with this GLTF data. This is used to find other files the GLTF file references, like images or binary buffers. This will be set during import when appending from a file, and will be set during export when writing to a file.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_property_buffers:
- .. rst-class:: classref-property
- :ref:`PackedByteArray[]<class_PackedByteArray>` **buffers** = ``[]``
- .. rst-class:: classref-property-setget
- - void **set_buffers** **(** :ref:`PackedByteArray[]<class_PackedByteArray>` value **)**
- - :ref:`PackedByteArray[]<class_PackedByteArray>` **get_buffers** **(** **)**
- .. container:: contribute
- There is currently no description for this property. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_property_copyright:
- .. rst-class:: classref-property
- :ref:`String<class_String>` **copyright** = ``""``
- .. rst-class:: classref-property-setget
- - void **set_copyright** **(** :ref:`String<class_String>` value **)**
- - :ref:`String<class_String>` **get_copyright** **(** **)**
- The copyright string in the asset header of the GLTF file. This is set during import if present and export if non-empty. See the GLTF asset header documentation for more information.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_property_create_animations:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **create_animations** = ``true``
- .. rst-class:: classref-property-setget
- - void **set_create_animations** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **get_create_animations** **(** **)**
- .. container:: contribute
- There is currently no description for this property. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_property_filename:
- .. rst-class:: classref-property
- :ref:`String<class_String>` **filename** = ``""``
- .. rst-class:: classref-property-setget
- - void **set_filename** **(** :ref:`String<class_String>` value **)**
- - :ref:`String<class_String>` **get_filename** **(** **)**
- The file name associated with this GLTF data. If it ends with ``.gltf``, this is text-based GLTF, otherwise this is binary GLB. This will be set during import when appending from a file, and will be set during export when writing to a file. If writing to a buffer, this will be an empty string.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_property_glb_data:
- .. rst-class:: classref-property
- :ref:`PackedByteArray<class_PackedByteArray>` **glb_data** = ``PackedByteArray()``
- .. rst-class:: classref-property-setget
- - void **set_glb_data** **(** :ref:`PackedByteArray<class_PackedByteArray>` value **)**
- - :ref:`PackedByteArray<class_PackedByteArray>` **get_glb_data** **(** **)**
- .. container:: contribute
- There is currently no description for this property. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_property_json:
- .. rst-class:: classref-property
- :ref:`Dictionary<class_Dictionary>` **json** = ``{}``
- .. rst-class:: classref-property-setget
- - void **set_json** **(** :ref:`Dictionary<class_Dictionary>` value **)**
- - :ref:`Dictionary<class_Dictionary>` **get_json** **(** **)**
- .. container:: contribute
- There is currently no description for this property. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_property_major_version:
- .. rst-class:: classref-property
- :ref:`int<class_int>` **major_version** = ``0``
- .. rst-class:: classref-property-setget
- - void **set_major_version** **(** :ref:`int<class_int>` value **)**
- - :ref:`int<class_int>` **get_major_version** **(** **)**
- .. container:: contribute
- There is currently no description for this property. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_property_minor_version:
- .. rst-class:: classref-property
- :ref:`int<class_int>` **minor_version** = ``0``
- .. rst-class:: classref-property-setget
- - void **set_minor_version** **(** :ref:`int<class_int>` value **)**
- - :ref:`int<class_int>` **get_minor_version** **(** **)**
- .. container:: contribute
- There is currently no description for this property. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_property_root_nodes:
- .. rst-class:: classref-property
- :ref:`PackedInt32Array<class_PackedInt32Array>` **root_nodes** = ``PackedInt32Array()``
- .. rst-class:: classref-property-setget
- - void **set_root_nodes** **(** :ref:`PackedInt32Array<class_PackedInt32Array>` value **)**
- - :ref:`PackedInt32Array<class_PackedInt32Array>` **get_root_nodes** **(** **)**
- The root nodes of the GLTF file. Typically, a GLTF file will only have one scene, and therefore one root node. However, a GLTF file may have multiple scenes and therefore multiple root nodes, which will be generated as siblings of each other and as children of the root node of the generated Godot scene.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_property_scene_name:
- .. rst-class:: classref-property
- :ref:`String<class_String>` **scene_name** = ``""``
- .. rst-class:: classref-property-setget
- - void **set_scene_name** **(** :ref:`String<class_String>` value **)**
- - :ref:`String<class_String>` **get_scene_name** **(** **)**
- The name of the scene. When importing, if not specified, this will be the file name. When exporting, if specified, the scene name will be saved to the GLTF file.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_property_use_named_skin_binds:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **use_named_skin_binds** = ``false``
- .. rst-class:: classref-property-setget
- - void **set_use_named_skin_binds** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **get_use_named_skin_binds** **(** **)**
- .. container:: contribute
- There is currently no description for this property. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Method Descriptions
- -------------------
- .. _class_GLTFState_method_add_used_extension:
- .. rst-class:: classref-method
- void **add_used_extension** **(** :ref:`String<class_String>` extension_name, :ref:`bool<class_bool>` required **)**
- Appends an extension to the list of extensions used by this GLTF file during serialization. If ``required`` is true, the extension will also be added to the list of required extensions. Do not run this in :ref:`GLTFDocumentExtension._export_post<class_GLTFDocumentExtension_private_method__export_post>`, as that stage is too late to add extensions. The final list is sorted alphabetically.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_accessors:
- .. rst-class:: classref-method
- :ref:`GLTFAccessor[]<class_GLTFAccessor>` **get_accessors** **(** **)**
- .. container:: contribute
- There is currently no description for this method. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_additional_data:
- .. rst-class:: classref-method
- :ref:`Variant<class_Variant>` **get_additional_data** **(** :ref:`StringName<class_StringName>` extension_name **)**
- Gets additional arbitrary data in this **GLTFState** instance. This can be used to keep per-file state data in :ref:`GLTFDocumentExtension<class_GLTFDocumentExtension>` classes, which is important because they are stateless.
- The argument should be the :ref:`GLTFDocumentExtension<class_GLTFDocumentExtension>` name (does not have to match the extension name in the GLTF file), and the return value can be anything you set. If nothing was set, the return value is null.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_animation_player:
- .. rst-class:: classref-method
- :ref:`AnimationPlayer<class_AnimationPlayer>` **get_animation_player** **(** :ref:`int<class_int>` idx **)**
- Returns the :ref:`AnimationPlayer<class_AnimationPlayer>` node with the given index. These nodes are only used during the export process when converting Godot :ref:`AnimationPlayer<class_AnimationPlayer>` nodes to GLTF animations.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_animation_players_count:
- .. rst-class:: classref-method
- :ref:`int<class_int>` **get_animation_players_count** **(** :ref:`int<class_int>` idx **)**
- Returns the number of :ref:`AnimationPlayer<class_AnimationPlayer>` nodes in this **GLTFState**. These nodes are only used during the export process when converting Godot :ref:`AnimationPlayer<class_AnimationPlayer>` nodes to GLTF animations.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_animations:
- .. rst-class:: classref-method
- :ref:`GLTFAnimation[]<class_GLTFAnimation>` **get_animations** **(** **)**
- Returns an array of all :ref:`GLTFAnimation<class_GLTFAnimation>`\ s in the GLTF file. When importing, these will be generated as animations in an :ref:`AnimationPlayer<class_AnimationPlayer>` node. When exporting, these will be generated from Godot :ref:`AnimationPlayer<class_AnimationPlayer>` nodes.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_buffer_views:
- .. rst-class:: classref-method
- :ref:`GLTFBufferView[]<class_GLTFBufferView>` **get_buffer_views** **(** **)**
- .. container:: contribute
- There is currently no description for this method. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_cameras:
- .. rst-class:: classref-method
- :ref:`GLTFCamera[]<class_GLTFCamera>` **get_cameras** **(** **)**
- Returns an array of all :ref:`GLTFCamera<class_GLTFCamera>`\ s in the GLTF file. These are the cameras that the :ref:`GLTFNode.camera<class_GLTFNode_property_camera>` index refers to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_handle_binary_image:
- .. rst-class:: classref-method
- :ref:`int<class_int>` **get_handle_binary_image** **(** **)**
- .. container:: contribute
- There is currently no description for this method. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_images:
- .. rst-class:: classref-method
- :ref:`Texture2D[]<class_Texture2D>` **get_images** **(** **)**
- Gets the images of the GLTF file as an array of :ref:`Texture2D<class_Texture2D>`\ s. These are the images that the :ref:`GLTFTexture.src_image<class_GLTFTexture_property_src_image>` index refers to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_lights:
- .. rst-class:: classref-method
- :ref:`GLTFLight[]<class_GLTFLight>` **get_lights** **(** **)**
- Returns an array of all :ref:`GLTFLight<class_GLTFLight>`\ s in the GLTF file. These are the lights that the :ref:`GLTFNode.light<class_GLTFNode_property_light>` index refers to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_materials:
- .. rst-class:: classref-method
- :ref:`Material[]<class_Material>` **get_materials** **(** **)**
- .. container:: contribute
- There is currently no description for this method. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_meshes:
- .. rst-class:: classref-method
- :ref:`GLTFMesh[]<class_GLTFMesh>` **get_meshes** **(** **)**
- Returns an array of all :ref:`GLTFMesh<class_GLTFMesh>`\ es in the GLTF file. These are the meshes that the :ref:`GLTFNode.mesh<class_GLTFNode_property_mesh>` index refers to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_node_index:
- .. rst-class:: classref-method
- :ref:`int<class_int>` **get_node_index** **(** :ref:`Node<class_Node>` scene_node **)**
- Returns the index of the :ref:`GLTFNode<class_GLTFNode>` corresponding to this Godot scene node. This is the inverse of :ref:`get_scene_node<class_GLTFState_method_get_scene_node>`. Useful during the export process.
- \ **Note:** Not every Godot scene node will have a corresponding :ref:`GLTFNode<class_GLTFNode>`, and not every :ref:`GLTFNode<class_GLTFNode>` will have a scene node generated. If there is no :ref:`GLTFNode<class_GLTFNode>` index for this scene node, ``-1`` is returned.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_nodes:
- .. rst-class:: classref-method
- :ref:`GLTFNode[]<class_GLTFNode>` **get_nodes** **(** **)**
- Returns an array of all :ref:`GLTFNode<class_GLTFNode>`\ s in the GLTF file. These are the nodes that :ref:`GLTFNode.children<class_GLTFNode_property_children>` and :ref:`root_nodes<class_GLTFState_property_root_nodes>` refer to. This includes nodes that may not be generated in the Godot scene, or nodes that may generate multiple Godot scene nodes.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_scene_node:
- .. rst-class:: classref-method
- :ref:`Node<class_Node>` **get_scene_node** **(** :ref:`int<class_int>` idx **)**
- Returns the Godot scene node that corresponds to the same index as the :ref:`GLTFNode<class_GLTFNode>` it was generated from. This is the inverse of :ref:`get_node_index<class_GLTFState_method_get_node_index>`. Useful during the import process.
- \ **Note:** Not every :ref:`GLTFNode<class_GLTFNode>` will have a scene node generated, and not every generated scene node will have a corresponding :ref:`GLTFNode<class_GLTFNode>`. If there is no scene node for this :ref:`GLTFNode<class_GLTFNode>` index, ``null`` is returned.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_skeletons:
- .. rst-class:: classref-method
- :ref:`GLTFSkeleton[]<class_GLTFSkeleton>` **get_skeletons** **(** **)**
- Returns an array of all :ref:`GLTFSkeleton<class_GLTFSkeleton>`\ s in the GLTF file. These are the skeletons that the :ref:`GLTFNode.skeleton<class_GLTFNode_property_skeleton>` index refers to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_skins:
- .. rst-class:: classref-method
- :ref:`GLTFSkin[]<class_GLTFSkin>` **get_skins** **(** **)**
- Returns an array of all :ref:`GLTFSkin<class_GLTFSkin>`\ s in the GLTF file. These are the skins that the :ref:`GLTFNode.skin<class_GLTFNode_property_skin>` index refers to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_texture_samplers:
- .. rst-class:: classref-method
- :ref:`GLTFTextureSampler[]<class_GLTFTextureSampler>` **get_texture_samplers** **(** **)**
- Retrieves the array of texture samplers that are used by the textures contained in the GLTF.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_textures:
- .. rst-class:: classref-method
- :ref:`GLTFTexture[]<class_GLTFTexture>` **get_textures** **(** **)**
- .. container:: contribute
- There is currently no description for this method. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_unique_animation_names:
- .. rst-class:: classref-method
- :ref:`String[]<class_String>` **get_unique_animation_names** **(** **)**
- Returns an array of unique animation names. This is only used during the import process.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_get_unique_names:
- .. rst-class:: classref-method
- :ref:`String[]<class_String>` **get_unique_names** **(** **)**
- Returns an array of unique node names. This is used in both the import process and export process.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_accessors:
- .. rst-class:: classref-method
- void **set_accessors** **(** :ref:`GLTFAccessor[]<class_GLTFAccessor>` accessors **)**
- .. container:: contribute
- There is currently no description for this method. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_additional_data:
- .. rst-class:: classref-method
- void **set_additional_data** **(** :ref:`StringName<class_StringName>` extension_name, :ref:`Variant<class_Variant>` additional_data **)**
- Sets additional arbitrary data in this **GLTFState** instance. This can be used to keep per-file state data in :ref:`GLTFDocumentExtension<class_GLTFDocumentExtension>` classes, which is important because they are stateless.
- The first argument should be the :ref:`GLTFDocumentExtension<class_GLTFDocumentExtension>` name (does not have to match the extension name in the GLTF file), and the second argument can be anything you want.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_animations:
- .. rst-class:: classref-method
- void **set_animations** **(** :ref:`GLTFAnimation[]<class_GLTFAnimation>` animations **)**
- Sets the :ref:`GLTFAnimation<class_GLTFAnimation>`\ s in the state. When importing, these will be generated as animations in an :ref:`AnimationPlayer<class_AnimationPlayer>` node. When exporting, these will be generated from Godot :ref:`AnimationPlayer<class_AnimationPlayer>` nodes.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_buffer_views:
- .. rst-class:: classref-method
- void **set_buffer_views** **(** :ref:`GLTFBufferView[]<class_GLTFBufferView>` buffer_views **)**
- .. container:: contribute
- There is currently no description for this method. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_cameras:
- .. rst-class:: classref-method
- void **set_cameras** **(** :ref:`GLTFCamera[]<class_GLTFCamera>` cameras **)**
- Sets the :ref:`GLTFCamera<class_GLTFCamera>`\ s in the state. These are the cameras that the :ref:`GLTFNode.camera<class_GLTFNode_property_camera>` index refers to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_handle_binary_image:
- .. rst-class:: classref-method
- void **set_handle_binary_image** **(** :ref:`int<class_int>` method **)**
- .. container:: contribute
- There is currently no description for this method. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_images:
- .. rst-class:: classref-method
- void **set_images** **(** :ref:`Texture2D[]<class_Texture2D>` images **)**
- Sets the images in the state stored as an array of :ref:`Texture2D<class_Texture2D>`\ s. This can be used during export. These are the images that the :ref:`GLTFTexture.src_image<class_GLTFTexture_property_src_image>` index refers to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_lights:
- .. rst-class:: classref-method
- void **set_lights** **(** :ref:`GLTFLight[]<class_GLTFLight>` lights **)**
- Sets the :ref:`GLTFLight<class_GLTFLight>`\ s in the state. These are the lights that the :ref:`GLTFNode.light<class_GLTFNode_property_light>` index refers to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_materials:
- .. rst-class:: classref-method
- void **set_materials** **(** :ref:`Material[]<class_Material>` materials **)**
- .. container:: contribute
- There is currently no description for this method. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_meshes:
- .. rst-class:: classref-method
- void **set_meshes** **(** :ref:`GLTFMesh[]<class_GLTFMesh>` meshes **)**
- Sets the :ref:`GLTFMesh<class_GLTFMesh>`\ es in the state. These are the meshes that the :ref:`GLTFNode.mesh<class_GLTFNode_property_mesh>` index refers to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_nodes:
- .. rst-class:: classref-method
- void **set_nodes** **(** :ref:`GLTFNode[]<class_GLTFNode>` nodes **)**
- Sets the :ref:`GLTFNode<class_GLTFNode>`\ s in the state. These are the nodes that :ref:`GLTFNode.children<class_GLTFNode_property_children>` and :ref:`root_nodes<class_GLTFState_property_root_nodes>` refer to. Some of the nodes set here may not be generated in the Godot scene, or may generate multiple Godot scene nodes.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_skeletons:
- .. rst-class:: classref-method
- void **set_skeletons** **(** :ref:`GLTFSkeleton[]<class_GLTFSkeleton>` skeletons **)**
- Sets the :ref:`GLTFSkeleton<class_GLTFSkeleton>`\ s in the state. These are the skeletons that the :ref:`GLTFNode.skeleton<class_GLTFNode_property_skeleton>` index refers to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_skins:
- .. rst-class:: classref-method
- void **set_skins** **(** :ref:`GLTFSkin[]<class_GLTFSkin>` skins **)**
- Sets the :ref:`GLTFSkin<class_GLTFSkin>`\ s in the state. These are the skins that the :ref:`GLTFNode.skin<class_GLTFNode_property_skin>` index refers to.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_texture_samplers:
- .. rst-class:: classref-method
- void **set_texture_samplers** **(** :ref:`GLTFTextureSampler[]<class_GLTFTextureSampler>` texture_samplers **)**
- Sets the array of texture samplers that are used by the textures contained in the GLTF.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_textures:
- .. rst-class:: classref-method
- void **set_textures** **(** :ref:`GLTFTexture[]<class_GLTFTexture>` textures **)**
- .. container:: contribute
- There is currently no description for this method. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`!
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_unique_animation_names:
- .. rst-class:: classref-method
- void **set_unique_animation_names** **(** :ref:`String[]<class_String>` unique_animation_names **)**
- Sets the unique animation names in the state. This is only used during the import process.
- .. rst-class:: classref-item-separator
- ----
- .. _class_GLTFState_method_set_unique_names:
- .. rst-class:: classref-method
- void **set_unique_names** **(** :ref:`String[]<class_String>` unique_names **)**
- Sets the unique node names in the state. This is used in both the import process and export process.
- .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
- .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
- .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`
- .. |constructor| replace:: :abbr:`constructor (This method is used to construct a type.)`
- .. |static| replace:: :abbr:`static (This method doesn't need an instance to be called, so it can be called directly using the class name.)`
- .. |operator| replace:: :abbr:`operator (This method describes a valid operator to use with this type as left-hand operand.)`
- .. |bitfield| replace:: :abbr:`BitField (This value is an integer composed as a bitmask of the following flags.)`
|