Skip to content

Commit 3a7efc9

Browse files
committed
Merge pull request #98874 from aaronfranke/gltf-preserve-visibility
GLTF: Preserve node visibility on import
2 parents 9b23b20 + 9247327 commit 3a7efc9

File tree

6 files changed

+6
-3
lines changed

6 files changed

+6
-3
lines changed

editor/import/3d/resource_importer_scene.cpp

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2622,6 +2622,7 @@ Node *ResourceImporterScene::_generate_meshes(Node *p_node, const Dictionary &p_
26222622

26232623
mesh_node->set_layer_mask(src_mesh_node->get_layer_mask());
26242624
mesh_node->set_cast_shadows_setting(src_mesh_node->get_cast_shadows_setting());
2625+
mesh_node->set_visible(src_mesh_node->is_visible());
26252626
mesh_node->set_visibility_range_begin(src_mesh_node->get_visibility_range_begin());
26262627
mesh_node->set_visibility_range_begin_margin(src_mesh_node->get_visibility_range_begin_margin());
26272628
mesh_node->set_visibility_range_end(src_mesh_node->get_visibility_range_end());

editor/import/3d/scene_import_settings.cpp

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -368,6 +368,7 @@ void SceneImportSettingsDialog::_fill_scene(Node *p_node, TreeItem *p_parent_ite
368368
mesh_node->set_transform(src_mesh_node->get_transform());
369369
mesh_node->set_skin(src_mesh_node->get_skin());
370370
mesh_node->set_skeleton_path(src_mesh_node->get_skeleton_path());
371+
mesh_node->set_visible(src_mesh_node->is_visible());
371372
if (src_mesh_node->get_mesh().is_valid()) {
372373
Ref<ImporterMesh> editor_mesh = src_mesh_node->get_mesh();
373374
mesh_node->set_mesh(editor_mesh->get_mesh());

modules/gltf/editor/editor_scene_exporter_gltf_plugin.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -88,7 +88,7 @@ void SceneExporterGLTFPlugin::_popup_gltf_export_dialog() {
8888
}
8989
_file_dialog->set_current_file(filename + String(".gltf"));
9090
// Generate and refresh the export settings.
91-
_export_settings->generate_property_list(_gltf_document);
91+
_export_settings->generate_property_list(_gltf_document, root);
9292
_settings_inspector->edit(nullptr);
9393
_settings_inspector->edit(_export_settings.ptr());
9494
// Show the file dialog.

modules/gltf/editor/editor_scene_exporter_gltf_settings.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -129,7 +129,7 @@ String get_friendly_config_prefix(Ref<GLTFDocumentExtension> p_extension) {
129129
}
130130

131131
// Run this before popping up the export settings, because the extensions may have changed.
132-
void EditorSceneExporterGLTFSettings::generate_property_list(Ref<GLTFDocument> p_document) {
132+
void EditorSceneExporterGLTFSettings::generate_property_list(Ref<GLTFDocument> p_document, Node *p_root) {
133133
_property_list.clear();
134134
_document = p_document;
135135
String image_format_hint_string = "None,PNG,JPEG";

modules/gltf/editor/editor_scene_exporter_gltf_settings.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -55,7 +55,7 @@ class EditorSceneExporterGLTFSettings : public RefCounted {
5555
bool _get_extension_setting(const String &p_name_str, Variant &r_ret) const;
5656

5757
public:
58-
void generate_property_list(Ref<GLTFDocument> p_document);
58+
void generate_property_list(Ref<GLTFDocument> p_document, Node *p_root = nullptr);
5959

6060
String get_copyright() const;
6161
void set_copyright(const String &p_copyright);

modules/gltf/extensions/gltf_document_extension_convert_importer_mesh.cpp

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -63,6 +63,7 @@ Error GLTFDocumentExtensionConvertImporterMesh::import_post(Ref<GLTFState> p_sta
6363
mesh_instance_node_3d->set_mesh(array_mesh);
6464
mesh_instance_node_3d->set_skin(importer_mesh_3d->get_skin());
6565
mesh_instance_node_3d->set_skeleton_path(importer_mesh_3d->get_skeleton_path());
66+
mesh_instance_node_3d->set_visible(importer_mesh_3d->is_visible());
6667
node->replace_by(mesh_instance_node_3d);
6768
_copy_meta(importer_mesh_3d, mesh_instance_node_3d);
6869
_copy_meta(mesh.ptr(), array_mesh.ptr());

0 commit comments

Comments
 (0)