summaryrefslogtreecommitdiffstats
path: root/editor/editor_data.cpp
diff options
context:
space:
mode:
authorYuri Sizov <yuris@humnom.net>2023-03-31 21:17:59 +0200
committerYuri Sizov <yuris@humnom.net>2023-03-31 21:17:59 +0200
commit9fae65404a223a86816685b0b4036a57b8f976b7 (patch)
treeeff64897c2dffdbbc2618366e714434e674e95da /editor/editor_data.cpp
parentc58080299a038d7cfcba7036bd969434ced39093 (diff)
downloadredot-engine-9fae65404a223a86816685b0b4036a57b8f976b7.tar.gz
Streamline class icon resolution in the editor
Diffstat (limited to 'editor/editor_data.cpp')
-rw-r--r--editor/editor_data.cpp55
1 files changed, 53 insertions, 2 deletions
diff --git a/editor/editor_data.cpp b/editor/editor_data.cpp
index 3059ce445c..d2af7879d2 100644
--- a/editor/editor_data.cpp
+++ b/editor/editor_data.cpp
@@ -32,9 +32,11 @@
#include "core/config/project_settings.h"
#include "core/io/file_access.h"
+#include "core/io/image_loader.h"
#include "core/io/resource_loader.h"
#include "editor/editor_node.h"
#include "editor/editor_plugin.h"
+#include "editor/editor_scale.h"
#include "editor/editor_undo_redo_manager.h"
#include "editor/plugins/script_editor_plugin.h"
#include "scene/resources/packed_scene.h"
@@ -457,10 +459,10 @@ void EditorData::add_custom_type(const String &p_type, const String &p_inherits,
ct.name = p_type;
ct.icon = p_icon;
ct.script = p_script;
+
if (!custom_types.has(p_inherits)) {
custom_types[p_inherits] = Vector<CustomType>();
}
-
custom_types[p_inherits].push_back(ct);
}
@@ -1028,8 +1030,57 @@ void EditorData::script_class_load_icon_paths() {
}
}
+Ref<ImageTexture> EditorData::_load_script_icon(const String &p_path) const {
+ if (p_path.length()) {
+ Ref<Image> img = memnew(Image);
+ Error err = ImageLoader::load_image(p_path, img);
+ if (err == OK) {
+ img->resize(16 * EDSCALE, 16 * EDSCALE, Image::INTERPOLATE_LANCZOS);
+ return ImageTexture::create_from_image(img);
+ }
+ }
+ return nullptr;
+}
+
+Ref<Texture2D> EditorData::get_script_icon(const Ref<Script> &p_script) {
+ // Take from the local cache, if available.
+ if (_script_icon_cache.has(p_script) && _script_icon_cache[p_script].is_valid()) {
+ return _script_icon_cache[p_script];
+ }
+
+ Ref<Script> base_scr = p_script;
+ while (base_scr.is_valid()) {
+ // Check for scripted classes.
+ StringName name = script_class_get_name(base_scr->get_path());
+ String icon_path = script_class_get_icon_path(name);
+ Ref<ImageTexture> icon = _load_script_icon(icon_path);
+ if (icon.is_valid()) {
+ _script_icon_cache[p_script] = icon;
+ return icon;
+ }
+
+ // Check for legacy custom classes defined by plugins.
+ // TODO: Should probably be deprecated in 4.x
+ const EditorData::CustomType *ctype = get_custom_type_by_path(base_scr->get_path());
+ if (ctype && ctype->icon.is_valid()) {
+ _script_icon_cache[p_script] = ctype->icon;
+ return ctype->icon;
+ }
+
+ // Move to the base class.
+ base_scr = base_scr->get_base_script();
+ }
+
+ // If no icon found, cache it as null.
+ _script_icon_cache[p_script] = Ref<Texture>();
+ return nullptr;
+}
+
+void EditorData::clear_script_icon_cache() {
+ _script_icon_cache.clear();
+}
+
EditorData::EditorData() {
- current_edited_scene = -1;
undo_redo_manager = memnew(EditorUndoRedoManager);
script_class_load_icon_paths();
}