Merge pull request #16241 from Chaosus/zoomlabel

Added zoom label to code editor
This commit is contained in:
Rémi Verschelde 2018-02-19 21:35:11 +01:00 committed by GitHub
commit f163b0e4b4
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 25 additions and 1 deletions

View file

@ -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);

View file

@ -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;