2023-01-05 12:25:55 +00:00
|
|
|
/**************************************************************************/
|
|
|
|
/* editor_resource_preview.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-04 23:50:27 +00:00
|
|
|
|
2022-07-23 21:41:51 +00:00
|
|
|
#ifndef EDITOR_RESOURCE_PREVIEW_H
|
|
|
|
#define EDITOR_RESOURCE_PREVIEW_H
|
2015-05-31 04:59:42 +00:00
|
|
|
|
2018-09-11 16:13:45 +00:00
|
|
|
#include "core/os/semaphore.h"
|
|
|
|
#include "core/os/thread.h"
|
2021-02-10 18:22:13 +00:00
|
|
|
#include "core/templates/safe_refcount.h"
|
2017-03-05 15:44:50 +00:00
|
|
|
#include "scene/main/node.h"
|
2023-07-11 20:29:09 +00:00
|
|
|
|
|
|
|
class ImageTexture;
|
|
|
|
class Texture2D;
|
2015-05-31 04:59:42 +00:00
|
|
|
|
2021-06-04 16:03:15 +00:00
|
|
|
class EditorResourcePreviewGenerator : public RefCounted {
|
|
|
|
GDCLASS(EditorResourcePreviewGenerator, RefCounted);
|
2015-05-31 04:59:42 +00:00
|
|
|
|
2016-09-10 18:32:17 +00:00
|
|
|
protected:
|
|
|
|
static void _bind_methods();
|
2015-05-31 04:59:42 +00:00
|
|
|
|
2021-08-22 01:52:44 +00:00
|
|
|
GDVIRTUAL1RC(bool, _handles, String)
|
2022-08-19 16:14:57 +00:00
|
|
|
GDVIRTUAL3RC(Ref<Texture2D>, _generate, Ref<Resource>, Vector2i, Dictionary)
|
|
|
|
GDVIRTUAL3RC(Ref<Texture2D>, _generate_from_path, String, Vector2i, Dictionary)
|
2021-08-22 01:52:44 +00:00
|
|
|
GDVIRTUAL0RC(bool, _generate_small_preview_automatically)
|
|
|
|
GDVIRTUAL0RC(bool, _can_generate_small_preview)
|
|
|
|
|
2024-02-21 09:44:21 +00:00
|
|
|
class DrawRequester : public Object {
|
|
|
|
Semaphore semaphore;
|
|
|
|
|
|
|
|
Variant _post_semaphore() const;
|
|
|
|
|
|
|
|
public:
|
|
|
|
void request_and_wait(RID p_viewport) const;
|
|
|
|
void abort() const;
|
|
|
|
};
|
|
|
|
|
2017-03-05 15:44:50 +00:00
|
|
|
public:
|
|
|
|
virtual bool handles(const String &p_type) const;
|
2022-08-19 16:14:57 +00:00
|
|
|
virtual Ref<Texture2D> generate(const Ref<Resource> &p_from, const Size2 &p_size, Dictionary &p_metadata) const;
|
|
|
|
virtual Ref<Texture2D> generate_from_path(const String &p_path, const Size2 &p_size, Dictionary &p_metadata) const;
|
2024-06-26 16:13:05 +00:00
|
|
|
virtual void abort() {}
|
2018-09-12 11:10:49 +00:00
|
|
|
|
2019-05-20 08:45:12 +00:00
|
|
|
virtual bool generate_small_preview_automatically() const;
|
|
|
|
virtual bool can_generate_small_preview() const;
|
2015-05-31 04:59:42 +00:00
|
|
|
|
|
|
|
EditorResourcePreviewGenerator();
|
|
|
|
};
|
|
|
|
|
|
|
|
class EditorResourcePreview : public Node {
|
2017-03-05 15:44:50 +00:00
|
|
|
GDCLASS(EditorResourcePreview, Node);
|
2015-05-31 04:59:42 +00:00
|
|
|
|
2023-05-31 14:52:50 +00:00
|
|
|
inline static constexpr int CURRENT_METADATA_VERSION = 1; // Increment this number to invalidate all previews.
|
|
|
|
inline static EditorResourcePreview *singleton = nullptr;
|
2015-05-31 04:59:42 +00:00
|
|
|
|
|
|
|
struct QueueItem {
|
2016-05-27 17:18:40 +00:00
|
|
|
Ref<Resource> resource;
|
2015-05-31 04:59:42 +00:00
|
|
|
String path;
|
|
|
|
ObjectID id;
|
|
|
|
StringName function;
|
|
|
|
Variant userdata;
|
|
|
|
};
|
|
|
|
|
|
|
|
List<QueueItem> queue;
|
|
|
|
|
2020-02-26 10:28:13 +00:00
|
|
|
Mutex preview_mutex;
|
2020-03-03 08:26:42 +00:00
|
|
|
Semaphore preview_sem;
|
2021-01-19 12:29:41 +00:00
|
|
|
Thread thread;
|
2023-11-10 14:27:51 +00:00
|
|
|
SafeFlag exiting;
|
2021-02-10 18:22:13 +00:00
|
|
|
SafeFlag exited;
|
2015-05-31 04:59:42 +00:00
|
|
|
|
|
|
|
struct Item {
|
2019-06-11 18:43:37 +00:00
|
|
|
Ref<Texture2D> preview;
|
|
|
|
Ref<Texture2D> small_preview;
|
2022-08-19 16:14:57 +00:00
|
|
|
Dictionary preview_metadata;
|
2020-11-24 09:12:55 +00:00
|
|
|
uint32_t last_hash = 0;
|
|
|
|
uint64_t modified_time = 0;
|
2015-05-31 04:59:42 +00:00
|
|
|
};
|
|
|
|
|
2022-05-13 13:04:37 +00:00
|
|
|
HashMap<String, Item> cache;
|
2015-05-31 04:59:42 +00:00
|
|
|
|
2022-08-19 16:14:57 +00:00
|
|
|
void _preview_ready(const String &p_path, int p_hash, const Ref<Texture2D> &p_texture, const Ref<Texture2D> &p_small_texture, ObjectID id, const StringName &p_func, const Variant &p_ud, const Dictionary &p_metadata);
|
|
|
|
void _generate_preview(Ref<ImageTexture> &r_texture, Ref<ImageTexture> &r_small_texture, const QueueItem &p_item, const String &cache_base, Dictionary &p_metadata);
|
2015-05-31 04:59:42 +00:00
|
|
|
|
2023-05-12 11:53:15 +00:00
|
|
|
int small_thumbnail_size = -1;
|
|
|
|
|
2015-05-31 04:59:42 +00:00
|
|
|
static void _thread_func(void *ud);
|
2024-01-15 18:34:06 +00:00
|
|
|
void _thread(); // For rendering drivers supporting async texture creation.
|
|
|
|
static void _idle_callback(); // For other rendering drivers (i.e., OpenGL).
|
2020-11-18 18:11:30 +00:00
|
|
|
void _iterate();
|
2015-05-31 04:59:42 +00:00
|
|
|
|
2024-02-15 16:25:58 +00:00
|
|
|
void _write_preview_cache(Ref<FileAccess> p_file, int p_thumbnail_size, bool p_has_small_texture, uint64_t p_modified_time, const String &p_hash, const Dictionary &p_metadata);
|
2023-05-31 14:52:50 +00:00
|
|
|
void _read_preview_cache(Ref<FileAccess> p_file, int *r_thumbnail_size, bool *r_has_small_texture, uint64_t *r_modified_time, String *r_hash, Dictionary *r_metadata, bool *r_outdated);
|
2022-08-19 16:14:57 +00:00
|
|
|
|
2020-03-17 06:33:00 +00:00
|
|
|
Vector<Ref<EditorResourcePreviewGenerator>> preview_generators;
|
2016-07-03 16:15:15 +00:00
|
|
|
|
2023-05-12 11:53:15 +00:00
|
|
|
void _update_thumbnail_sizes();
|
|
|
|
|
2015-05-31 04:59:42 +00:00
|
|
|
protected:
|
|
|
|
static void _bind_methods();
|
|
|
|
|
2017-03-05 15:44:50 +00:00
|
|
|
public:
|
|
|
|
static EditorResourcePreview *get_singleton();
|
2015-05-31 04:59:42 +00:00
|
|
|
|
2021-05-26 07:19:46 +00:00
|
|
|
// p_receiver_func callback has signature (String p_path, Ref<Texture2D> p_preview, Ref<Texture2D> p_preview_small, Variant p_userdata)
|
|
|
|
// p_preview will be null if there was an error
|
2017-08-12 16:52:50 +00:00
|
|
|
void queue_resource_preview(const String &p_path, Object *p_receiver, const StringName &p_receiver_func, const Variant &p_userdata);
|
|
|
|
void queue_edited_resource_preview(const Ref<Resource> &p_res, Object *p_receiver, const StringName &p_receiver_func, const Variant &p_userdata);
|
2022-07-20 21:44:06 +00:00
|
|
|
const Dictionary get_preview_metadata(const String &p_path) const;
|
2015-05-31 04:59:42 +00:00
|
|
|
|
2017-03-05 15:44:50 +00:00
|
|
|
void add_preview_generator(const Ref<EditorResourcePreviewGenerator> &p_generator);
|
|
|
|
void remove_preview_generator(const Ref<EditorResourcePreviewGenerator> &p_generator);
|
|
|
|
void check_for_invalidation(const String &p_path);
|
2015-05-31 04:59:42 +00:00
|
|
|
|
2019-02-27 16:31:11 +00:00
|
|
|
void start();
|
2019-01-17 12:09:01 +00:00
|
|
|
void stop();
|
2024-02-21 09:44:21 +00:00
|
|
|
bool is_threaded() const;
|
2019-01-17 12:09:01 +00:00
|
|
|
|
2015-05-31 04:59:42 +00:00
|
|
|
EditorResourcePreview();
|
|
|
|
~EditorResourcePreview();
|
|
|
|
};
|
|
|
|
|
2022-07-23 21:41:51 +00:00
|
|
|
#endif // EDITOR_RESOURCE_PREVIEW_H
|