RichTextLabel add function remove_line
This commit is contained in:
parent
da11d6d9e8
commit
c20b186e73
@ -1214,6 +1214,28 @@ void RichTextLabel::_add_item(Item *p_item, bool p_enter, bool p_ensure_newline)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void RichTextLabel::_remove_item(Item* p_item, const int p_line, const int p_subitem_line) {
|
||||||
|
|
||||||
|
|
||||||
|
int size = p_item->subitems.size();
|
||||||
|
if (size == 0) {
|
||||||
|
p_item->parent->subitems.erase(p_item);
|
||||||
|
if (p_item->type == ITEM_NEWLINE) {
|
||||||
|
current_frame->lines.remove(p_line);
|
||||||
|
for (int i = p_subitem_line; i < current->subitems.size(); i++) {
|
||||||
|
if (current->subitems[i]->line > 0)
|
||||||
|
current->subitems[i]->line--;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
for (int i = 0; i < size; i++) {
|
||||||
|
_remove_item(p_item->subitems.front()->get(), p_line, p_subitem_line);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
void RichTextLabel::add_image(const Ref<Texture>& p_image) {
|
void RichTextLabel::add_image(const Ref<Texture>& p_image) {
|
||||||
|
|
||||||
if (current->type==ITEM_TABLE)
|
if (current->type==ITEM_TABLE)
|
||||||
@ -1238,6 +1260,26 @@ void RichTextLabel::add_newline() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool RichTextLabel::remove_line(const int p_line) {
|
||||||
|
|
||||||
|
if (p_line >= current_frame->lines.size() || p_line < 0)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
int lines = p_line * 2;
|
||||||
|
|
||||||
|
if (current->subitems[lines]->type != ITEM_NEWLINE)
|
||||||
|
_remove_item(current->subitems[lines], current->subitems[lines]->line, lines);
|
||||||
|
|
||||||
|
_remove_item(current->subitems[lines], current->subitems[lines]->line, lines);
|
||||||
|
|
||||||
|
if (p_line == 0) {
|
||||||
|
main->lines[0].from = main;
|
||||||
|
}
|
||||||
|
|
||||||
|
main->first_invalid_line = 0;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
void RichTextLabel::push_font(const Ref<Font>& p_font) {
|
void RichTextLabel::push_font(const Ref<Font>& p_font) {
|
||||||
|
|
||||||
ERR_FAIL_COND(current->type==ITEM_TABLE);
|
ERR_FAIL_COND(current->type==ITEM_TABLE);
|
||||||
@ -1906,6 +1948,7 @@ void RichTextLabel::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("add_text","text"),&RichTextLabel::add_text);
|
ClassDB::bind_method(D_METHOD("add_text","text"),&RichTextLabel::add_text);
|
||||||
ClassDB::bind_method(D_METHOD("add_image","image:Texture"),&RichTextLabel::add_image);
|
ClassDB::bind_method(D_METHOD("add_image","image:Texture"),&RichTextLabel::add_image);
|
||||||
ClassDB::bind_method(D_METHOD("newline"),&RichTextLabel::add_newline);
|
ClassDB::bind_method(D_METHOD("newline"),&RichTextLabel::add_newline);
|
||||||
|
ClassDB::bind_method(D_METHOD("remove_line"),&RichTextLabel::remove_line);
|
||||||
ClassDB::bind_method(D_METHOD("push_font","font"),&RichTextLabel::push_font);
|
ClassDB::bind_method(D_METHOD("push_font","font"),&RichTextLabel::push_font);
|
||||||
ClassDB::bind_method(D_METHOD("push_color","color"),&RichTextLabel::push_color);
|
ClassDB::bind_method(D_METHOD("push_color","color"),&RichTextLabel::push_color);
|
||||||
ClassDB::bind_method(D_METHOD("push_align","align"),&RichTextLabel::push_align);
|
ClassDB::bind_method(D_METHOD("push_align","align"),&RichTextLabel::push_align);
|
||||||
|
@ -217,6 +217,7 @@ private:
|
|||||||
void _validate_line_caches(ItemFrame *p_frame);
|
void _validate_line_caches(ItemFrame *p_frame);
|
||||||
|
|
||||||
void _add_item(Item *p_item, bool p_enter=false,bool p_ensure_newline=false);
|
void _add_item(Item *p_item, bool p_enter=false,bool p_ensure_newline=false);
|
||||||
|
void _remove_item(Item *p_item, const int p_line, const int p_subitem_line);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -284,6 +285,7 @@ public:
|
|||||||
void add_text(const String& p_text);
|
void add_text(const String& p_text);
|
||||||
void add_image(const Ref<Texture>& p_image);
|
void add_image(const Ref<Texture>& p_image);
|
||||||
void add_newline();
|
void add_newline();
|
||||||
|
bool remove_line(const int p_line);
|
||||||
void push_font(const Ref<Font>& p_font);
|
void push_font(const Ref<Font>& p_font);
|
||||||
void push_color(const Color& p_color);
|
void push_color(const Color& p_color);
|
||||||
void push_underline();
|
void push_underline();
|
||||||
|
Loading…
Reference in New Issue
Block a user