Ported: [3.x] Add deselect() to RichTextLabel - ConteZero

5e714051ea
This commit is contained in:
Relintai 2022-07-25 22:01:26 +02:00
parent d1ddbecc54
commit 220b7e99be
3 changed files with 22 additions and 13 deletions

View File

@ -48,6 +48,12 @@
Clears the tag stack and sets [member bbcode_text] to an empty string. Clears the tag stack and sets [member bbcode_text] to an empty string.
</description> </description>
</method> </method>
<method name="deselect">
<return type="void" />
<description>
Clears the current selection.
</description>
</method>
<method name="get_content_height" qualifiers="const"> <method name="get_content_height" qualifiers="const">
<return type="int" /> <return type="int" />
<description> <description>

View File

@ -1068,8 +1068,7 @@ void RichTextLabel::_notification(int p_what) {
} break; } break;
case NOTIFICATION_FOCUS_EXIT: { case NOTIFICATION_FOCUS_EXIT: {
if (deselect_on_focus_loss_enabled) { if (deselect_on_focus_loss_enabled) {
selection.active = false; deselect();
update();
} }
} break; } break;
case Control::NOTIFICATION_DRAG_END: { case Control::NOTIFICATION_DRAG_END: {
@ -1177,9 +1176,8 @@ void RichTextLabel::_gui_input(Ref<InputEvent> p_event) {
selection.from_char = '\0'; selection.from_char = '\0';
selection.to = nullptr; selection.to = nullptr;
selection.to_char = '\0'; selection.to_char = '\0';
selection.active = false;
update(); deselect();
} }
} }
} }
@ -1226,9 +1224,8 @@ void RichTextLabel::_gui_input(Ref<InputEvent> p_event) {
selection.from_char = '\0'; selection.from_char = '\0';
selection.to = nullptr; selection.to = nullptr;
selection.to_char = '\0'; selection.to_char = '\0';
selection.active = false;
update(); deselect();
} }
} }
@ -1362,7 +1359,7 @@ void RichTextLabel::_gui_input(Ref<InputEvent> p_event) {
if (selection.from_char > selection.to_char) { if (selection.from_char > selection.to_char) {
swap = true; swap = true;
} else if (selection.from_char == selection.to_char) { } else if (selection.from_char == selection.to_char) {
selection.active = false; deselect();
return; return;
} }
} }
@ -2002,10 +1999,10 @@ void RichTextLabel::clear() {
main->lines.clear(); main->lines.clear();
main->lines.resize(1); main->lines.resize(1);
main->first_invalid_line = 0; main->first_invalid_line = 0;
update();
selection.click = nullptr; selection.click = nullptr;
selection.active = false; deselect();
current_idx = 1; current_idx = 1;
if (scroll_follow) { if (scroll_follow) {
scroll_following = true; scroll_following = true;
} }
@ -2532,8 +2529,7 @@ void RichTextLabel::set_selection_enabled(bool p_enabled) {
selection.enabled = p_enabled; selection.enabled = p_enabled;
if (!p_enabled) { if (!p_enabled) {
if (selection.active) { if (selection.active) {
selection.active = false; deselect();
update();
} }
set_focus_mode(FOCUS_NONE); set_focus_mode(FOCUS_NONE);
} else { } else {
@ -2544,8 +2540,7 @@ void RichTextLabel::set_selection_enabled(bool p_enabled) {
void RichTextLabel::set_deselect_on_focus_loss_enabled(const bool p_enabled) { void RichTextLabel::set_deselect_on_focus_loss_enabled(const bool p_enabled) {
deselect_on_focus_loss_enabled = p_enabled; deselect_on_focus_loss_enabled = p_enabled;
if (p_enabled && selection.active && !has_focus()) { if (p_enabled && selection.active && !has_focus()) {
selection.active = false; deselect();
update();
} }
} }
@ -2664,6 +2659,11 @@ String RichTextLabel::get_selected_text() {
return text; return text;
} }
void RichTextLabel::deselect() {
selection.active = false;
update();
}
void RichTextLabel::selection_copy() { void RichTextLabel::selection_copy() {
String text = get_selected_text(); String text = get_selected_text();
@ -2814,6 +2814,8 @@ void RichTextLabel::_bind_methods() {
ClassDB::bind_method(D_METHOD("pop"), &RichTextLabel::pop); ClassDB::bind_method(D_METHOD("pop"), &RichTextLabel::pop);
ClassDB::bind_method(D_METHOD("clear"), &RichTextLabel::clear); ClassDB::bind_method(D_METHOD("clear"), &RichTextLabel::clear);
ClassDB::bind_method(D_METHOD("deselect"), &RichTextLabel::deselect);
ClassDB::bind_method(D_METHOD("get_selected_text"), &RichTextLabel::get_selected_text); ClassDB::bind_method(D_METHOD("get_selected_text"), &RichTextLabel::get_selected_text);
ClassDB::bind_method(D_METHOD("set_meta_underline", "enable"), &RichTextLabel::set_meta_underline); ClassDB::bind_method(D_METHOD("set_meta_underline", "enable"), &RichTextLabel::set_meta_underline);

View File

@ -479,6 +479,7 @@ public:
void set_deselect_on_focus_loss_enabled(const bool p_enabled); void set_deselect_on_focus_loss_enabled(const bool p_enabled);
bool is_deselect_on_focus_loss_enabled() const; bool is_deselect_on_focus_loss_enabled() const;
void deselect();
Error parse_bbcode(const String &p_bbcode); Error parse_bbcode(const String &p_bbcode);
Error append_bbcode(const String &p_bbcode); Error append_bbcode(const String &p_bbcode);