diff --git a/editor_modules/gltf/gltf_document.cpp b/editor_modules/gltf/gltf_document.cpp index 99d61452c..3e868f4f2 100644 --- a/editor_modules/gltf/gltf_document.cpp +++ b/editor_modules/gltf/gltf_document.cpp @@ -3129,6 +3129,7 @@ Error GLTFDocument::_parse_images(Ref p_state, const String &p_base_p Ref texture = ResourceLoader::load(uri); if (texture.is_valid()) { p_state->images.push_back(texture->get_data()); + p_state->external_images_paths.insert(i, uri); continue; } else if (mimetype == "image/png" || mimetype == "image/jpeg") { // Fallback to loading as byte array. @@ -3257,17 +3258,25 @@ Error GLTFDocument::_parse_textures(Ref p_state) { } p_state->textures.push_back(t); + Ref tex; + // Create and cache the texture used in the engine - Ref imgTex; - imgTex.instance(); - imgTex->create_from_image(p_state->images[t->get_src_image()]); + if (p_state->external_images_paths.has(t->get_src_image())) { + tex = ResourceLoader::load(p_state->external_images_paths[t->get_src_image()]); + } else { + Ref img_tex; + img_tex.instance(); + img_tex->create_from_image(p_state->images[t->get_src_image()]); - // Set texture filter and repeat based on sampler settings - const Ref sampler = _get_sampler_for_texture(p_state, i); - Texture::Flags flags = sampler->get_texture_flags(); - imgTex->set_flags(flags); + // Set texture filter and repeat based on sampler settings. Only supported for embedded textures + const Ref sampler = _get_sampler_for_texture(p_state, i); + Texture::Flags flags = sampler->get_texture_flags(); + img_tex->set_flags(flags); - p_state->texture_cache.insert(i, imgTex); + tex = img_tex; + } + + p_state->texture_cache.insert(i, tex); } return OK; diff --git a/editor_modules/gltf/gltf_state.h b/editor_modules/gltf/gltf_state.h index 038be0105..0a8bd270b 100644 --- a/editor_modules/gltf/gltf_state.h +++ b/editor_modules/gltf/gltf_state.h @@ -79,6 +79,7 @@ class GLTFState : public Resource { Vector> texture_samplers; Ref default_texture_sampler; Vector> images; + RBMap external_images_paths; RBMap> texture_cache; Vector extensions_used; Vector extensions_required;