2023-01-10 15:26:54 +01:00
|
|
|
/**************************************************************************/
|
|
|
|
/* resource_importer_scene.h */
|
|
|
|
/**************************************************************************/
|
|
|
|
/* This file is part of: */
|
|
|
|
/* GODOT ENGINE */
|
|
|
|
/* https://godotengine.org */
|
|
|
|
/**************************************************************************/
|
|
|
|
/* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
|
|
|
|
/* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
|
|
|
|
/* */
|
|
|
|
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
|
|
/* a copy of this software and associated documentation files (the */
|
|
|
|
/* "Software"), to deal in the Software without restriction, including */
|
|
|
|
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
|
|
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
|
|
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
|
|
/* the following conditions: */
|
|
|
|
/* */
|
|
|
|
/* The above copyright notice and this permission notice shall be */
|
|
|
|
/* included in all copies or substantial portions of the Software. */
|
|
|
|
/* */
|
|
|
|
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
|
|
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
|
|
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */
|
|
|
|
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
|
|
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
|
|
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
|
|
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
|
|
/**************************************************************************/
|
2018-01-05 00:50:27 +01:00
|
|
|
|
2022-07-25 12:33:41 +02:00
|
|
|
#ifndef RESOURCE_IMPORTER_SCENE_H
|
|
|
|
#define RESOURCE_IMPORTER_SCENE_H
|
2017-02-04 13:48:04 +01:00
|
|
|
|
2019-02-12 13:30:56 +01:00
|
|
|
#include "core/io/resource_importer.h"
|
2017-02-04 13:48:04 +01:00
|
|
|
#include "scene/resources/animation.h"
|
2017-06-07 23:18:55 +02:00
|
|
|
#include "scene/resources/mesh.h"
|
2017-02-04 13:48:04 +01:00
|
|
|
#include "scene/resources/shape.h"
|
|
|
|
|
2017-02-05 00:31:15 +01:00
|
|
|
class Material;
|
2017-02-04 13:48:04 +01:00
|
|
|
class EditorSceneImporter : public Reference {
|
2017-03-05 16:44:50 +01:00
|
|
|
GDCLASS(EditorSceneImporter, Reference);
|
2017-12-07 19:44:20 +01:00
|
|
|
|
2017-12-09 18:11:26 +01:00
|
|
|
protected:
|
2017-12-07 19:44:20 +01:00
|
|
|
static void _bind_methods();
|
2017-02-04 13:48:04 +01:00
|
|
|
|
2021-05-10 22:51:11 +02:00
|
|
|
Node *import_scene_from_other_importer(const String &p_path, uint32_t p_flags, int p_bake_fps, uint32_t p_compress_flags);
|
2017-12-07 19:44:20 +01:00
|
|
|
Ref<Animation> import_animation_from_other_importer(const String &p_path, uint32_t p_flags, int p_bake_fps);
|
2017-12-09 18:11:26 +01:00
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
public:
|
2017-02-04 13:48:04 +01:00
|
|
|
enum ImportFlags {
|
2017-03-05 16:44:50 +01:00
|
|
|
IMPORT_SCENE = 1,
|
|
|
|
IMPORT_ANIMATION = 2,
|
|
|
|
IMPORT_ANIMATION_DETECT_LOOP = 4,
|
|
|
|
IMPORT_ANIMATION_OPTIMIZE = 8,
|
|
|
|
IMPORT_ANIMATION_FORCE_ALL_TRACKS_IN_ALL_CLIPS = 16,
|
|
|
|
IMPORT_ANIMATION_KEEP_VALUE_TRACKS = 32,
|
|
|
|
IMPORT_GENERATE_TANGENT_ARRAYS = 256,
|
|
|
|
IMPORT_FAIL_ON_MISSING_DEPENDENCIES = 512,
|
2017-11-01 01:01:24 +01:00
|
|
|
IMPORT_MATERIALS_IN_INSTANCES = 1024,
|
2020-02-21 11:27:48 +01:00
|
|
|
IMPORT_USE_COMPRESSION = 2048,
|
|
|
|
IMPORT_USE_NAMED_SKIN_BINDS = 4096,
|
2021-04-21 06:06:00 +02:00
|
|
|
IMPORT_USE_LEGACY_NAMES = 8192,
|
2017-02-04 13:48:04 +01:00
|
|
|
|
|
|
|
};
|
|
|
|
|
2017-12-07 19:44:20 +01:00
|
|
|
virtual uint32_t get_import_flags() const;
|
|
|
|
virtual void get_extensions(List<String> *r_extensions) const;
|
2021-05-10 22:51:11 +02:00
|
|
|
virtual Node *import_scene(const String &p_path, uint32_t p_flags, int p_bake_fps, uint32_t p_compress_flags, List<String> *r_missing_deps, Error *r_err = nullptr);
|
2017-12-09 18:11:26 +01:00
|
|
|
virtual Ref<Animation> import_animation(const String &p_path, uint32_t p_flags, int p_bake_fps);
|
2017-02-04 13:48:04 +01:00
|
|
|
|
|
|
|
EditorSceneImporter() {}
|
|
|
|
};
|
|
|
|
|
|
|
|
class EditorScenePostImport : public Reference {
|
2017-03-05 16:44:50 +01:00
|
|
|
GDCLASS(EditorScenePostImport, Reference);
|
2017-02-04 13:48:04 +01:00
|
|
|
|
2018-01-20 00:48:44 +01:00
|
|
|
String source_folder;
|
|
|
|
String source_file;
|
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
protected:
|
2017-02-04 13:48:04 +01:00
|
|
|
static void _bind_methods();
|
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
public:
|
2018-01-20 00:48:44 +01:00
|
|
|
String get_source_folder() const;
|
|
|
|
String get_source_file() const;
|
2017-03-05 16:44:50 +01:00
|
|
|
virtual Node *post_import(Node *p_scene);
|
2019-06-26 15:08:25 +02:00
|
|
|
virtual void init(const String &p_source_folder, const String &p_source_file);
|
2017-02-04 13:48:04 +01:00
|
|
|
EditorScenePostImport();
|
|
|
|
};
|
|
|
|
|
|
|
|
class ResourceImporterScene : public ResourceImporter {
|
2019-03-19 19:35:57 +01:00
|
|
|
GDCLASS(ResourceImporterScene, ResourceImporter);
|
2017-02-04 13:48:04 +01:00
|
|
|
|
2021-05-04 14:20:36 +02:00
|
|
|
Set<Ref<EditorSceneImporter>> importers;
|
2017-02-04 13:48:04 +01:00
|
|
|
|
|
|
|
static ResourceImporterScene *singleton;
|
|
|
|
|
2017-07-23 23:48:05 +02:00
|
|
|
enum Presets {
|
|
|
|
PRESET_SEPARATE_MATERIALS,
|
|
|
|
PRESET_SEPARATE_MESHES,
|
2017-09-19 10:51:00 +02:00
|
|
|
PRESET_SEPARATE_ANIMATIONS,
|
2017-09-08 13:06:09 +02:00
|
|
|
|
2017-08-30 02:54:26 +02:00
|
|
|
PRESET_SINGLE_SCENE,
|
2017-09-08 13:06:09 +02:00
|
|
|
|
2017-07-23 23:48:05 +02:00
|
|
|
PRESET_SEPARATE_MESHES_AND_MATERIALS,
|
2017-09-08 13:06:09 +02:00
|
|
|
PRESET_SEPARATE_MESHES_AND_ANIMATIONS,
|
2017-09-19 10:51:00 +02:00
|
|
|
PRESET_SEPARATE_MATERIALS_AND_ANIMATIONS,
|
|
|
|
PRESET_SEPARATE_MESHES_MATERIALS_AND_ANIMATIONS,
|
2017-09-08 13:06:09 +02:00
|
|
|
|
2017-07-23 23:48:05 +02:00
|
|
|
PRESET_MULTIPLE_SCENES,
|
|
|
|
PRESET_MULTIPLE_SCENES_AND_MATERIALS,
|
2017-09-21 01:59:19 +02:00
|
|
|
PRESET_MAX
|
2017-07-23 23:48:05 +02:00
|
|
|
};
|
|
|
|
|
2017-11-25 05:29:15 +01:00
|
|
|
enum LightBakeMode {
|
|
|
|
LIGHT_BAKE_DISABLED,
|
|
|
|
LIGHT_BAKE_ENABLE,
|
2018-10-07 16:18:27 +02:00
|
|
|
LIGHT_BAKE_LIGHTMAPS
|
2017-11-25 05:29:15 +01:00
|
|
|
};
|
|
|
|
|
2017-07-23 23:48:05 +02:00
|
|
|
void _replace_owner(Node *p_node, Node *p_scene, Node *p_new_owner);
|
2021-05-04 14:20:36 +02:00
|
|
|
void _add_shapes(Node *p_node, const List<Ref<Shape>> &p_shapes);
|
2017-07-23 23:48:05 +02:00
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
public:
|
2017-02-04 13:48:04 +01:00
|
|
|
static ResourceImporterScene *get_singleton() { return singleton; }
|
|
|
|
|
2021-05-04 14:20:36 +02:00
|
|
|
const Set<Ref<EditorSceneImporter>> &get_importers() const { return importers; }
|
2017-02-04 13:48:04 +01:00
|
|
|
|
|
|
|
void add_importer(Ref<EditorSceneImporter> p_importer) { importers.insert(p_importer); }
|
2017-12-07 19:44:20 +01:00
|
|
|
void remove_importer(Ref<EditorSceneImporter> p_importer) { importers.erase(p_importer); }
|
2017-02-04 13:48:04 +01:00
|
|
|
|
|
|
|
virtual String get_importer_name() const;
|
|
|
|
virtual String get_visible_name() const;
|
|
|
|
virtual void get_recognized_extensions(List<String> *p_extensions) const;
|
|
|
|
virtual String get_save_extension() const;
|
|
|
|
virtual String get_resource_type() const;
|
|
|
|
|
|
|
|
virtual int get_preset_count() const;
|
|
|
|
virtual String get_preset_name(int p_idx) const;
|
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
virtual void get_import_options(List<ImportOption> *r_options, int p_preset = 0) const;
|
|
|
|
virtual bool get_option_visibility(const String &p_option, const Map<StringName, Variant> &p_options) const;
|
2021-07-23 12:10:32 +02:00
|
|
|
// Import scenes *after* everything else (such as textures).
|
|
|
|
virtual int get_import_order() const { return ResourceImporter::IMPORT_ORDER_SCENE; }
|
2017-02-04 13:48:04 +01:00
|
|
|
|
2017-12-09 18:11:26 +01:00
|
|
|
void _find_meshes(Node *p_node, Map<Ref<ArrayMesh>, Transform> &meshes);
|
|
|
|
|
2021-05-04 14:20:36 +02:00
|
|
|
void _make_external_resources(Node *p_node, const String &p_base_path, bool p_make_animations, bool p_animations_as_text, bool p_keep_animations, bool p_make_materials, bool p_materials_as_text, bool p_keep_materials, bool p_make_meshes, bool p_meshes_as_text, Map<Ref<Animation>, Ref<Animation>> &p_animations, Map<Ref<Material>, Ref<Material>> &p_materials, Map<Ref<ArrayMesh>, Ref<ArrayMesh>> &p_meshes);
|
2017-02-05 00:31:15 +01:00
|
|
|
|
2022-01-19 16:25:51 +01:00
|
|
|
Node *_fix_node(Node *p_node, Node *p_root, Map<Ref<Mesh>, List<Ref<Shape>>> &collision_map, LightBakeMode p_light_bake_mode, List<Pair<NodePath, Node *>> &r_node_renames);
|
2017-02-04 13:48:04 +01:00
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
void _create_clips(Node *scene, const Array &p_clips, bool p_bake_all);
|
|
|
|
void _filter_anim_tracks(Ref<Animation> anim, Set<String> &keep);
|
|
|
|
void _filter_tracks(Node *scene, const String &p_text);
|
|
|
|
void _optimize_animations(Node *scene, float p_max_lin_error, float p_max_ang_error, float p_max_angle);
|
2017-02-04 13:48:04 +01:00
|
|
|
|
2021-05-04 16:00:45 +02:00
|
|
|
virtual Error import(const String &p_source_file, const String &p_save_path, const Map<StringName, Variant> &p_options, List<String> *r_platform_variants, List<String> *r_gen_files = nullptr, Variant *r_metadata = nullptr);
|
2017-02-04 13:48:04 +01:00
|
|
|
|
2021-05-10 22:51:11 +02:00
|
|
|
Node *import_scene_from_other_importer(EditorSceneImporter *p_exception, const String &p_path, uint32_t p_flags, int p_bake_fps, uint32_t p_compress_flags);
|
2017-12-09 18:11:26 +01:00
|
|
|
Ref<Animation> import_animation_from_other_importer(EditorSceneImporter *p_exception, const String &p_path, uint32_t p_flags, int p_bake_fps);
|
2017-12-07 19:44:20 +01:00
|
|
|
|
2017-02-04 13:48:04 +01:00
|
|
|
ResourceImporterScene();
|
|
|
|
};
|
|
|
|
|
2018-01-30 15:03:46 +01:00
|
|
|
class EditorSceneImporterESCN : public EditorSceneImporter {
|
|
|
|
GDCLASS(EditorSceneImporterESCN, EditorSceneImporter);
|
|
|
|
|
|
|
|
public:
|
|
|
|
virtual uint32_t get_import_flags() const;
|
|
|
|
virtual void get_extensions(List<String> *r_extensions) const;
|
2021-05-10 22:51:11 +02:00
|
|
|
virtual Node *import_scene(const String &p_path, uint32_t p_flags, int p_bake_fps, uint32_t p_compress_flags, List<String> *r_missing_deps, Error *r_err = nullptr);
|
2018-01-30 15:03:46 +01:00
|
|
|
virtual Ref<Animation> import_animation(const String &p_path, uint32_t p_flags, int p_bake_fps);
|
|
|
|
};
|
|
|
|
|
2022-07-25 12:33:41 +02:00
|
|
|
#endif // RESOURCE_IMPORTER_SCENE_H
|