Update TextureRect and Sprite when their Texture is modified directly.

Modified Sprite to use "changed" signal instead of _changed_callback to make it work when tool is disabled (change receptors are editor only).

Fixes #32349
This commit is contained in:
PouleyKetchoupp 2019-09-25 20:48:48 +02:00
parent 0ea54eeb06
commit c7834ee566
5 changed files with 40 additions and 11 deletions

View file

@ -135,12 +135,12 @@ void Sprite::set_texture(const Ref<Texture> &p_texture) {
return; return;
if (texture.is_valid()) if (texture.is_valid())
texture->remove_change_receptor(this); texture->disconnect(CoreStringNames::get_singleton()->changed, this, "_texture_changed");
texture = p_texture; texture = p_texture;
if (texture.is_valid()) if (texture.is_valid())
texture->add_change_receptor(this); texture->connect(CoreStringNames::get_singleton()->changed, this, "_texture_changed");
update(); update();
emit_signal("texture_changed"); emit_signal("texture_changed");
@ -389,11 +389,11 @@ void Sprite::_validate_property(PropertyInfo &property) const {
} }
} }
void Sprite::_changed_callback(Object *p_changed, const char *p_prop) { void Sprite::_texture_changed() {
// Changes to the texture need to trigger an update to make // Changes to the texture need to trigger an update to make
// the editor redraw the sprite with the updated texture. // the editor redraw the sprite with the updated texture.
if (texture.is_valid() && texture.ptr() == p_changed) { if (texture.is_valid()) {
update(); update();
} }
} }
@ -443,6 +443,8 @@ void Sprite::_bind_methods() {
ClassDB::bind_method(D_METHOD("get_rect"), &Sprite::get_rect); ClassDB::bind_method(D_METHOD("get_rect"), &Sprite::get_rect);
ClassDB::bind_method(D_METHOD("_texture_changed"), &Sprite::_texture_changed);
ADD_SIGNAL(MethodInfo("frame_changed")); ADD_SIGNAL(MethodInfo("frame_changed"));
ADD_SIGNAL(MethodInfo("texture_changed")); ADD_SIGNAL(MethodInfo("texture_changed"));
@ -480,6 +482,4 @@ Sprite::Sprite() {
} }
Sprite::~Sprite() { Sprite::~Sprite() {
if (texture.is_valid())
texture->remove_change_receptor(this);
} }

View file

@ -57,6 +57,8 @@ class Sprite : public Node2D {
void _get_rects(Rect2 &r_src_rect, Rect2 &r_dst_rect, bool &r_filter_clip) const; void _get_rects(Rect2 &r_src_rect, Rect2 &r_dst_rect, bool &r_filter_clip) const;
void _texture_changed();
protected: protected:
void _notification(int p_what); void _notification(int p_what);
@ -64,8 +66,6 @@ protected:
virtual void _validate_property(PropertyInfo &property) const; virtual void _validate_property(PropertyInfo &property) const;
virtual void _changed_callback(Object *p_changed, const char *p_prop);
public: public:
virtual Dictionary _edit_get_state() const; virtual Dictionary _edit_get_state() const;
virtual void _edit_set_state(const Dictionary &p_state); virtual void _edit_set_state(const Dictionary &p_state);

View file

@ -29,6 +29,7 @@
/*************************************************************************/ /*************************************************************************/
#include "texture_rect.h" #include "texture_rect.h"
#include "core/core_string_names.h"
#include "servers/visual_server.h" #include "servers/visual_server.h"
void TextureRect::_notification(int p_what) { void TextureRect::_notification(int p_what) {
@ -123,6 +124,7 @@ void TextureRect::_bind_methods() {
ClassDB::bind_method(D_METHOD("is_flipped_v"), &TextureRect::is_flipped_v); ClassDB::bind_method(D_METHOD("is_flipped_v"), &TextureRect::is_flipped_v);
ClassDB::bind_method(D_METHOD("set_stretch_mode", "stretch_mode"), &TextureRect::set_stretch_mode); ClassDB::bind_method(D_METHOD("set_stretch_mode", "stretch_mode"), &TextureRect::set_stretch_mode);
ClassDB::bind_method(D_METHOD("get_stretch_mode"), &TextureRect::get_stretch_mode); ClassDB::bind_method(D_METHOD("get_stretch_mode"), &TextureRect::get_stretch_mode);
ClassDB::bind_method(D_METHOD("_texture_changed"), &TextureRect::_texture_changed);
ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "texture", PROPERTY_HINT_RESOURCE_TYPE, "Texture"), "set_texture", "get_texture"); ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "texture", PROPERTY_HINT_RESOURCE_TYPE, "Texture"), "set_texture", "get_texture");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "expand"), "set_expand", "has_expand"); ADD_PROPERTY(PropertyInfo(Variant::BOOL, "expand"), "set_expand", "has_expand");
@ -140,9 +142,27 @@ void TextureRect::_bind_methods() {
BIND_ENUM_CONSTANT(STRETCH_KEEP_ASPECT_COVERED); BIND_ENUM_CONSTANT(STRETCH_KEEP_ASPECT_COVERED);
} }
void TextureRect::_texture_changed() {
if (texture.is_valid()) {
update();
minimum_size_changed();
}
}
void TextureRect::set_texture(const Ref<Texture> &p_tex) { void TextureRect::set_texture(const Ref<Texture> &p_tex) {
if (p_tex == texture)
return;
if (texture.is_valid())
texture->disconnect(CoreStringNames::get_singleton()->changed, this, "_texture_changed");
texture = p_tex; texture = p_tex;
if (texture.is_valid())
texture->connect(CoreStringNames::get_singleton()->changed, this, "_texture_changed");
update(); update();
/* /*
if (texture.is_valid()) if (texture.is_valid())

View file

@ -56,6 +56,8 @@ private:
Ref<Texture> texture; Ref<Texture> texture;
StretchMode stretch_mode; StretchMode stretch_mode;
void _texture_changed();
protected: protected:
void _notification(int p_what); void _notification(int p_what);
virtual Size2 get_minimum_size() const; virtual Size2 get_minimum_size() const;

View file

@ -117,6 +117,7 @@ void ImageTexture::reload_from_file() {
} else { } else {
Resource::reload_from_file(); Resource::reload_from_file();
_change_notify(); _change_notify();
emit_changed();
} }
} }
@ -180,6 +181,7 @@ void ImageTexture::_reload_hook(const RID &p_hook) {
VisualServer::get_singleton()->texture_set_data(texture, img); VisualServer::get_singleton()->texture_set_data(texture, img);
_change_notify(); _change_notify();
emit_changed();
} }
void ImageTexture::create(int p_width, int p_height, Image::Format p_format, uint32_t p_flags) { void ImageTexture::create(int p_width, int p_height, Image::Format p_format, uint32_t p_flags) {
@ -190,6 +192,7 @@ void ImageTexture::create(int p_width, int p_height, Image::Format p_format, uin
w = p_width; w = p_width;
h = p_height; h = p_height;
_change_notify(); _change_notify();
emit_changed();
} }
void ImageTexture::create_from_image(const Ref<Image> &p_image, uint32_t p_flags) { void ImageTexture::create_from_image(const Ref<Image> &p_image, uint32_t p_flags) {
@ -202,23 +205,23 @@ void ImageTexture::create_from_image(const Ref<Image> &p_image, uint32_t p_flags
VisualServer::get_singleton()->texture_allocate(texture, p_image->get_width(), p_image->get_height(), 0, p_image->get_format(), VS::TEXTURE_TYPE_2D, p_flags); VisualServer::get_singleton()->texture_allocate(texture, p_image->get_width(), p_image->get_height(), 0, p_image->get_format(), VS::TEXTURE_TYPE_2D, p_flags);
VisualServer::get_singleton()->texture_set_data(texture, p_image); VisualServer::get_singleton()->texture_set_data(texture, p_image);
_change_notify(); _change_notify();
emit_changed();
image_stored = true; image_stored = true;
} }
void ImageTexture::set_flags(uint32_t p_flags) { void ImageTexture::set_flags(uint32_t p_flags) {
/* uint32_t cube = flags & FLAG_CUBEMAP; if (flags == p_flags)
if (flags == p_flags&cube)
return; return;
flags=p_flags|cube; */
flags = p_flags; flags = p_flags;
if (w == 0 || h == 0) { if (w == 0 || h == 0) {
return; //uninitialized, do not set to texture return; //uninitialized, do not set to texture
} }
VisualServer::get_singleton()->texture_set_flags(texture, p_flags); VisualServer::get_singleton()->texture_set_flags(texture, p_flags);
_change_notify("flags"); _change_notify("flags");
emit_changed();
} }
uint32_t ImageTexture::get_flags() const { uint32_t ImageTexture::get_flags() const {
@ -250,6 +253,8 @@ void ImageTexture::set_data(const Ref<Image> &p_image) {
VisualServer::get_singleton()->texture_set_data(texture, p_image); VisualServer::get_singleton()->texture_set_data(texture, p_image);
_change_notify(); _change_notify();
emit_changed();
alpha_cache.unref(); alpha_cache.unref();
image_stored = true; image_stored = true;
} }
@ -736,6 +741,7 @@ Error StreamTexture::load(const String &p_path) {
format = image->get_format(); format = image->get_format();
_change_notify(); _change_notify();
emit_changed();
return OK; return OK;
} }
String StreamTexture::get_load_path() const { String StreamTexture::get_load_path() const {
@ -827,6 +833,7 @@ void StreamTexture::set_flags(uint32_t p_flags) {
flags = p_flags; flags = p_flags;
VS::get_singleton()->texture_set_flags(texture, flags); VS::get_singleton()->texture_set_flags(texture, flags);
_change_notify("flags"); _change_notify("flags");
emit_changed();
} }
void StreamTexture::reload_from_file() { void StreamTexture::reload_from_file() {