Merge pull request #16241 from Chaosus/zoomlabel
Added zoom label to code editor
This commit is contained in:
commit
f163b0e4b4
2 changed files with 25 additions and 1 deletions
|
@ -666,6 +666,7 @@ void CodeTextEditor::_reset_zoom() {
|
||||||
if (font.is_valid()) {
|
if (font.is_valid()) {
|
||||||
EditorSettings::get_singleton()->set("interface/editor/code_font_size", 14);
|
EditorSettings::get_singleton()->set("interface/editor/code_font_size", 14);
|
||||||
font->set_size(14);
|
font->set_size(14);
|
||||||
|
zoom_nb->set_text("100%");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -727,6 +728,9 @@ bool CodeTextEditor::_add_font_size(int p_delta) {
|
||||||
|
|
||||||
if (font.is_valid()) {
|
if (font.is_valid()) {
|
||||||
int new_size = CLAMP(font->get_size() + p_delta, 8 * EDSCALE, 96 * EDSCALE);
|
int new_size = CLAMP(font->get_size() + p_delta, 8 * EDSCALE, 96 * EDSCALE);
|
||||||
|
|
||||||
|
zoom_nb->set_text(itos(100 * new_size / 14) + "%");
|
||||||
|
|
||||||
if (new_size != font->get_size()) {
|
if (new_size != font->get_size()) {
|
||||||
EditorSettings::get_singleton()->set("interface/editor/code_font_size", new_size / EDSCALE);
|
EditorSettings::get_singleton()->set("interface/editor/code_font_size", new_size / EDSCALE);
|
||||||
font->set_size(new_size);
|
font->set_size(new_size);
|
||||||
|
@ -886,6 +890,24 @@ CodeTextEditor::CodeTextEditor() {
|
||||||
|
|
||||||
status_bar->add_child(memnew(Label)); //to keep the height if the other labels are not visible
|
status_bar->add_child(memnew(Label)); //to keep the height if the other labels are not visible
|
||||||
|
|
||||||
|
Label *zoom_txt = memnew(Label);
|
||||||
|
status_bar->add_child(zoom_txt);
|
||||||
|
zoom_txt->set_align(Label::ALIGN_RIGHT);
|
||||||
|
zoom_txt->set_valign(Label::VALIGN_CENTER);
|
||||||
|
zoom_txt->set_v_size_flags(SIZE_FILL);
|
||||||
|
zoom_txt->set_text(TTR("Zoom:"));
|
||||||
|
zoom_txt->add_font_override("font", EditorNode::get_singleton()->get_gui_base()->get_font("status_source", "EditorFonts"));
|
||||||
|
|
||||||
|
zoom_nb = memnew(Label);
|
||||||
|
status_bar->add_child(zoom_nb);
|
||||||
|
zoom_nb->set_valign(Label::VALIGN_CENTER);
|
||||||
|
zoom_nb->set_v_size_flags(SIZE_FILL);
|
||||||
|
zoom_nb->set_autowrap(true); // workaround to prevent resizing the label on each change, do not touch
|
||||||
|
zoom_nb->set_clip_text(true); // workaround to prevent resizing the label on each change, do not touch
|
||||||
|
zoom_nb->set_custom_minimum_size(Size2(60, 1) * EDSCALE);
|
||||||
|
zoom_nb->set_align(Label::ALIGN_RIGHT);
|
||||||
|
zoom_nb->add_font_override("font", EditorNode::get_singleton()->get_gui_base()->get_font("status_source", "EditorFonts"));
|
||||||
|
|
||||||
Label *line_txt = memnew(Label);
|
Label *line_txt = memnew(Label);
|
||||||
status_bar->add_child(line_txt);
|
status_bar->add_child(line_txt);
|
||||||
line_txt->set_align(Label::ALIGN_RIGHT);
|
line_txt->set_align(Label::ALIGN_RIGHT);
|
||||||
|
@ -939,7 +961,8 @@ CodeTextEditor::CodeTextEditor() {
|
||||||
code_complete_timer->connect("timeout", this, "_code_complete_timer_timeout");
|
code_complete_timer->connect("timeout", this, "_code_complete_timer_timeout");
|
||||||
|
|
||||||
font_resize_val = 0;
|
font_resize_val = 0;
|
||||||
font_size = -1;
|
font_size = EditorSettings::get_singleton()->get("interface/editor/code_font_size");
|
||||||
|
zoom_nb->set_text(itos(100 * font_size / 14) + "%");
|
||||||
font_resize_timer = memnew(Timer);
|
font_resize_timer = memnew(Timer);
|
||||||
add_child(font_resize_timer);
|
add_child(font_resize_timer);
|
||||||
font_resize_timer->set_one_shot(true);
|
font_resize_timer->set_one_shot(true);
|
||||||
|
|
|
@ -145,6 +145,7 @@ class CodeTextEditor : public VBoxContainer {
|
||||||
|
|
||||||
Label *line_nb;
|
Label *line_nb;
|
||||||
Label *col_nb;
|
Label *col_nb;
|
||||||
|
Label *zoom_nb;
|
||||||
Label *info;
|
Label *info;
|
||||||
Timer *idle;
|
Timer *idle;
|
||||||
Timer *code_complete_timer;
|
Timer *code_complete_timer;
|
||||||
|
|
Loading…
Reference in a new issue