From a8a52f576e45fb9702b995addc634ed8497edb02 Mon Sep 17 00:00:00 2001 From: opl- Date: Sat, 25 Jul 2020 21:42:01 +0200 Subject: [PATCH] Fix DynamicFont breaking mouse grab in inspector spinners This was caused by DynamicFont not specifying which property was edited, resulting in the whole inspector property tree being recreated. --- scene/resources/dynamic_font.cpp | 21 ++++++++++----------- scene/resources/dynamic_font.h | 2 +- 2 files changed, 11 insertions(+), 12 deletions(-) diff --git a/scene/resources/dynamic_font.cpp b/scene/resources/dynamic_font.cpp index 2858305dbd6..cc7490b193d 100644 --- a/scene/resources/dynamic_font.cpp +++ b/scene/resources/dynamic_font.cpp @@ -670,7 +670,7 @@ DynamicFontAtSize::~DynamicFontAtSize() { ///////////////////////// -void DynamicFont::_reload_cache() { +void DynamicFont::_reload_cache(const char *p_triggering_property) { ERR_FAIL_COND(cache_id.size < 1); if (!data.is_valid()) { data_at_size.unref(); @@ -698,15 +698,12 @@ void DynamicFont::_reload_cache() { } emit_changed(); - _change_notify(); + _change_notify(p_triggering_property); } void DynamicFont::set_font_data(const Ref &p_data) { data = p_data; - _reload_cache(); - - emit_changed(); - _change_notify(); + _reload_cache(); // not passing the prop name as clearing the font data also clears fallbacks } Ref DynamicFont::get_font_data() const { @@ -719,7 +716,7 @@ void DynamicFont::set_size(int p_size) { } cache_id.size = p_size; outline_cache_id.size = p_size; - _reload_cache(); + _reload_cache("size"); } int DynamicFont::get_size() const { @@ -732,7 +729,7 @@ void DynamicFont::set_outline_size(int p_size) { } ERR_FAIL_COND(p_size < 0 || p_size > UINT8_MAX); outline_cache_id.outline_size = p_size; - _reload_cache(); + _reload_cache("outline_size"); } int DynamicFont::get_outline_size() const { @@ -743,7 +740,7 @@ void DynamicFont::set_outline_color(Color p_color) { if (p_color != outline_color) { outline_color = p_color; emit_changed(); - _change_notify(); + _change_notify("outline_color"); } } @@ -816,16 +813,19 @@ int DynamicFont::get_spacing(int p_type) const { void DynamicFont::set_spacing(int p_type, int p_value) { if (p_type == SPACING_TOP) { spacing_top = p_value; + _change_notify("extra_spacing_top"); } else if (p_type == SPACING_BOTTOM) { spacing_bottom = p_value; + _change_notify("extra_spacing_bottom"); } else if (p_type == SPACING_CHAR) { spacing_char = p_value; + _change_notify("extra_spacing_char"); } else if (p_type == SPACING_SPACE) { spacing_space = p_value; + _change_notify("extra_spacing_space"); } emit_changed(); - _change_notify(); } float DynamicFont::get_height() const { @@ -929,7 +929,6 @@ void DynamicFont::add_fallback(const Ref &p_data) { fallback_outline_data_at_size.push_back(fallbacks.write[fallbacks.size() - 1]->_get_dynamic_font_at_size(outline_cache_id)); } - _change_notify(); emit_changed(); _change_notify(); } diff --git a/scene/resources/dynamic_font.h b/scene/resources/dynamic_font.h index 591e9aeadac..469d740deaf 100644 --- a/scene/resources/dynamic_font.h +++ b/scene/resources/dynamic_font.h @@ -232,7 +232,7 @@ private: Color outline_color; protected: - void _reload_cache(); + void _reload_cache(const char *p_triggering_property = ""); bool _set(const StringName &p_name, const Variant &p_value); bool _get(const StringName &p_name, Variant &r_ret) const;