RichTextLabel returns member (Array) for custom effects for Editor

As RichTextLabel returned a copy of the member (Vector) the editor was notified
that the value had changed which caused the dropdown menu to be immediately
closed after opening.

The fix is to return the member (Array) in stead of a copy which is the same
instance and thereby does not notify the editor that the value has changed.
This commit is contained in:
William Deurwaarder 2021-08-24 22:02:24 +02:00
parent ca7f53dd25
commit d875706e01
2 changed files with 11 additions and 19 deletions

View file

@ -3946,24 +3946,15 @@ float RichTextLabel::get_percent_visible() const {
return percent_visible; return percent_visible;
} }
void RichTextLabel::set_effects(const Vector<Variant> &effects) { void RichTextLabel::set_effects(Array p_effects) {
custom_effects.clear(); custom_effects = p_effects;
for (int i = 0; i < effects.size(); i++) {
Ref<RichTextEffect> effect = Ref<RichTextEffect>(effects[i]);
custom_effects.push_back(effect);
}
if ((bbcode != "") && use_bbcode) { if ((bbcode != "") && use_bbcode) {
parse_bbcode(bbcode); parse_bbcode(bbcode);
} }
} }
Vector<Variant> RichTextLabel::get_effects() { Array RichTextLabel::get_effects() {
Vector<Variant> r; return custom_effects;
for (int i = 0; i < custom_effects.size(); i++) {
r.push_back(custom_effects[i]);
}
return r;
} }
void RichTextLabel::install_effect(const Variant effect) { void RichTextLabel::install_effect(const Variant effect) {
@ -4279,12 +4270,13 @@ void RichTextLabel::_draw_fbg_boxes(RID p_ci, RID p_rid, Vector2 line_off, Item
Ref<RichTextEffect> RichTextLabel::_get_custom_effect_by_code(String p_bbcode_identifier) { Ref<RichTextEffect> RichTextLabel::_get_custom_effect_by_code(String p_bbcode_identifier) {
for (int i = 0; i < custom_effects.size(); i++) { for (int i = 0; i < custom_effects.size(); i++) {
if (!custom_effects[i].is_valid()) { Ref<RichTextEffect> effect = custom_effects[i];
if (!effect.is_valid()) {
continue; continue;
} }
if (custom_effects[i]->get_bbcode() == p_bbcode_identifier) { if (effect->get_bbcode() == p_bbcode_identifier) {
return custom_effects[i]; return effect;
} }
} }

View file

@ -363,7 +363,7 @@ private:
ItemMeta *meta_hovering = nullptr; ItemMeta *meta_hovering = nullptr;
Variant current_meta; Variant current_meta;
Vector<Ref<RichTextEffect>> custom_effects; Array custom_effects;
void _invalidate_current_line(ItemFrame *p_frame); void _invalidate_current_line(ItemFrame *p_frame);
void _validate_line_caches(ItemFrame *p_frame); void _validate_line_caches(ItemFrame *p_frame);
@ -577,8 +577,8 @@ public:
void set_percent_visible(float p_percent); void set_percent_visible(float p_percent);
float get_percent_visible() const; float get_percent_visible() const;
void set_effects(const Vector<Variant> &effects); void set_effects(Array p_effects);
Vector<Variant> get_effects(); Array get_effects();
void install_effect(const Variant effect); void install_effect(const Variant effect);