Added caret blink in text editor
(cherry picked from commit e03e7deb1b
)
This commit is contained in:
parent
abc97d3bb4
commit
bd51dea8f6
|
@ -906,14 +906,18 @@ void TextEdit::_notification(int p_what) {
|
||||||
if (cursor.column==j && cursor.line==line) {
|
if (cursor.column==j && cursor.line==line) {
|
||||||
|
|
||||||
cursor_pos = Point2i( char_ofs+char_margin, ofs_y );
|
cursor_pos = Point2i( char_ofs+char_margin, ofs_y );
|
||||||
|
|
||||||
if (insert_mode) {
|
if (insert_mode) {
|
||||||
cursor_pos.y += get_row_height();
|
cursor_pos.y += get_row_height();
|
||||||
VisualServer::get_singleton()->canvas_item_add_rect(ci,Rect2(cursor_pos, Size2i(char_w,1)),cache.caret_color);
|
|
||||||
} else {
|
|
||||||
VisualServer::get_singleton()->canvas_item_add_rect(ci,Rect2(cursor_pos, Size2i(1,get_row_height())),cache.caret_color);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (draw_caret) {
|
||||||
|
if (insert_mode) {
|
||||||
|
VisualServer::get_singleton()->canvas_item_add_rect(ci,Rect2(cursor_pos, Size2i(char_w,1)),cache.caret_color);
|
||||||
|
} else {
|
||||||
|
VisualServer::get_singleton()->canvas_item_add_rect(ci,Rect2(cursor_pos, Size2i(1,get_row_height())),cache.caret_color);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
char_ofs+=char_w;
|
char_ofs+=char_w;
|
||||||
|
|
||||||
|
@ -922,12 +926,18 @@ void TextEdit::_notification(int p_what) {
|
||||||
if (cursor.column==str.length() && cursor.line==line && (char_ofs+char_margin)>=xmargin_beg) {
|
if (cursor.column==str.length() && cursor.line==line && (char_ofs+char_margin)>=xmargin_beg) {
|
||||||
|
|
||||||
cursor_pos=Point2i( char_ofs+char_margin, ofs_y );
|
cursor_pos=Point2i( char_ofs+char_margin, ofs_y );
|
||||||
|
|
||||||
if (insert_mode) {
|
if (insert_mode) {
|
||||||
cursor_pos.y += get_row_height();
|
cursor_pos.y += get_row_height();
|
||||||
int char_w = cache.font->get_char_size(' ').width;
|
}
|
||||||
VisualServer::get_singleton()->canvas_item_add_rect(ci,Rect2(cursor_pos, Size2i(char_w,1)),cache.caret_color);
|
|
||||||
} else {
|
if (draw_caret) {
|
||||||
VisualServer::get_singleton()->canvas_item_add_rect(ci,Rect2(cursor_pos, Size2i(1,get_row_height())),cache.caret_color);
|
if (insert_mode) {
|
||||||
|
int char_w = cache.font->get_char_size(' ').width;
|
||||||
|
VisualServer::get_singleton()->canvas_item_add_rect(ci,Rect2(cursor_pos, Size2i(char_w,1)),cache.caret_color);
|
||||||
|
} else {
|
||||||
|
VisualServer::get_singleton()->canvas_item_add_rect(ci,Rect2(cursor_pos, Size2i(1,get_row_height())),cache.caret_color);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1375,6 +1385,8 @@ void TextEdit::_input_event(const InputEvent& p_input_event) {
|
||||||
}
|
}
|
||||||
if (mb.button_index==BUTTON_LEFT) {
|
if (mb.button_index==BUTTON_LEFT) {
|
||||||
|
|
||||||
|
_reset_caret_blink_timer();
|
||||||
|
|
||||||
int row,col;
|
int row,col;
|
||||||
_get_mouse_pos(Point2i(mb.x,mb.y), row,col);
|
_get_mouse_pos(Point2i(mb.x,mb.y), row,col);
|
||||||
|
|
||||||
|
@ -1509,6 +1521,8 @@ void TextEdit::_input_event(const InputEvent& p_input_event) {
|
||||||
|
|
||||||
if (selection.selecting_mode!=Selection::MODE_NONE) {
|
if (selection.selecting_mode!=Selection::MODE_NONE) {
|
||||||
|
|
||||||
|
_reset_caret_blink_timer();
|
||||||
|
|
||||||
int row,col;
|
int row,col;
|
||||||
_get_mouse_pos(Point2i(mm.x,mm.y), row,col);
|
_get_mouse_pos(Point2i(mm.x,mm.y), row,col);
|
||||||
|
|
||||||
|
@ -1629,6 +1643,8 @@ void TextEdit::_input_event(const InputEvent& p_input_event) {
|
||||||
|
|
||||||
if (k.scancode==KEY_BACKSPACE) {
|
if (k.scancode==KEY_BACKSPACE) {
|
||||||
|
|
||||||
|
_reset_caret_blink_timer();
|
||||||
|
|
||||||
backspace_at_cursor();
|
backspace_at_cursor();
|
||||||
_update_completion_candidates();
|
_update_completion_candidates();
|
||||||
accept_event();
|
accept_event();
|
||||||
|
@ -1644,6 +1660,8 @@ void TextEdit::_input_event(const InputEvent& p_input_event) {
|
||||||
|
|
||||||
if (k.unicode>32) {
|
if (k.unicode>32) {
|
||||||
|
|
||||||
|
_reset_caret_blink_timer();
|
||||||
|
|
||||||
const CharType chr[2] = {(CharType)k.unicode, 0};
|
const CharType chr[2] = {(CharType)k.unicode, 0};
|
||||||
if(auto_brace_completion_enabled && _is_pair_symbol(chr[0])) {
|
if(auto_brace_completion_enabled && _is_pair_symbol(chr[0])) {
|
||||||
_consume_pair_symbol(chr[0]);
|
_consume_pair_symbol(chr[0]);
|
||||||
|
@ -1690,6 +1708,9 @@ void TextEdit::_input_event(const InputEvent& p_input_event) {
|
||||||
k.mod.shift=false;
|
k.mod.shift=false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!k.mod.command) {
|
||||||
|
_reset_caret_blink_timer();
|
||||||
|
}
|
||||||
// save here for insert mode, just in case it is cleared in the following section
|
// save here for insert mode, just in case it is cleared in the following section
|
||||||
bool had_selection = selection.active;
|
bool had_selection = selection.active;
|
||||||
|
|
||||||
|
@ -2866,6 +2887,30 @@ int TextEdit::cursor_get_line() const {
|
||||||
return cursor.line;
|
return cursor.line;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool TextEdit::cursor_get_blink_enabled() const {
|
||||||
|
return caret_blink_enabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
void TextEdit::cursor_set_blink_enabled(const bool p_enabled) {
|
||||||
|
caret_blink_enabled = p_enabled;
|
||||||
|
|
||||||
|
if (p_enabled) {
|
||||||
|
caret_blink_timer->start();
|
||||||
|
} else {
|
||||||
|
caret_blink_timer->stop();
|
||||||
|
}
|
||||||
|
draw_caret = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float TextEdit::cursor_get_blink_speed() const {
|
||||||
|
return caret_blink_timer->get_wait_time();
|
||||||
|
}
|
||||||
|
|
||||||
|
void TextEdit::cursor_set_blink_speed(const float p_speed) {
|
||||||
|
ERR_FAIL_COND(p_speed <= 0);
|
||||||
|
caret_blink_timer->set_wait_time(p_speed);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void TextEdit::_scroll_moved(double p_to_val) {
|
void TextEdit::_scroll_moved(double p_to_val) {
|
||||||
|
@ -3081,6 +3126,20 @@ void TextEdit::set_max_chars(int p_max_chars) {
|
||||||
max_chars=p_max_chars;
|
max_chars=p_max_chars;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TextEdit::_reset_caret_blink_timer() {
|
||||||
|
if (caret_blink_enabled) {
|
||||||
|
caret_blink_timer->stop();
|
||||||
|
caret_blink_timer->start();
|
||||||
|
draw_caret = true;
|
||||||
|
update();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void TextEdit::_toggle_draw_caret() {
|
||||||
|
draw_caret = !draw_caret;
|
||||||
|
update();
|
||||||
|
}
|
||||||
|
|
||||||
void TextEdit::_update_caches() {
|
void TextEdit::_update_caches() {
|
||||||
|
|
||||||
cache.style_normal=get_stylebox("normal");
|
cache.style_normal=get_stylebox("normal");
|
||||||
|
@ -4059,6 +4118,7 @@ void TextEdit::_bind_methods() {
|
||||||
ObjectTypeDB::bind_method(_MD("_text_changed_emit"),&TextEdit::_text_changed_emit);
|
ObjectTypeDB::bind_method(_MD("_text_changed_emit"),&TextEdit::_text_changed_emit);
|
||||||
ObjectTypeDB::bind_method(_MD("_push_current_op"),&TextEdit::_push_current_op);
|
ObjectTypeDB::bind_method(_MD("_push_current_op"),&TextEdit::_push_current_op);
|
||||||
ObjectTypeDB::bind_method(_MD("_click_selection_held"),&TextEdit::_click_selection_held);
|
ObjectTypeDB::bind_method(_MD("_click_selection_held"),&TextEdit::_click_selection_held);
|
||||||
|
ObjectTypeDB::bind_method(_MD("_toggle_draw_caret"),&TextEdit::_toggle_draw_caret);
|
||||||
|
|
||||||
BIND_CONSTANT( SEARCH_MATCH_CASE );
|
BIND_CONSTANT( SEARCH_MATCH_CASE );
|
||||||
BIND_CONSTANT( SEARCH_WHOLE_WORDS );
|
BIND_CONSTANT( SEARCH_WHOLE_WORDS );
|
||||||
|
@ -4128,6 +4188,7 @@ TextEdit::TextEdit() {
|
||||||
readonly=false;
|
readonly=false;
|
||||||
setting_row=false;
|
setting_row=false;
|
||||||
draw_tabs=false;
|
draw_tabs=false;
|
||||||
|
draw_caret=true;
|
||||||
max_chars=0;
|
max_chars=0;
|
||||||
clear();
|
clear();
|
||||||
wrap=false;
|
wrap=false;
|
||||||
|
@ -4167,6 +4228,13 @@ TextEdit::TextEdit() {
|
||||||
selection.active=false;
|
selection.active=false;
|
||||||
syntax_coloring=false;
|
syntax_coloring=false;
|
||||||
|
|
||||||
|
caret_blink_enabled=false;
|
||||||
|
caret_blink_timer = memnew(Timer);
|
||||||
|
add_child(caret_blink_timer);
|
||||||
|
caret_blink_timer->set_wait_time(0.65);
|
||||||
|
caret_blink_timer->connect("timeout", this,"_toggle_draw_caret");
|
||||||
|
cursor_set_blink_enabled(false);
|
||||||
|
|
||||||
custom_bg_color=Color(0,0,0,0);
|
custom_bg_color=Color(0,0,0,0);
|
||||||
idle_detect = memnew( Timer );
|
idle_detect = memnew( Timer );
|
||||||
add_child(idle_detect);
|
add_child(idle_detect);
|
||||||
|
|
|
@ -209,6 +209,10 @@ class TextEdit : public Control {
|
||||||
bool syntax_coloring;
|
bool syntax_coloring;
|
||||||
int tab_size;
|
int tab_size;
|
||||||
|
|
||||||
|
Timer *caret_blink_timer;
|
||||||
|
bool caret_blink_enabled;
|
||||||
|
bool draw_caret;
|
||||||
|
|
||||||
bool setting_row;
|
bool setting_row;
|
||||||
bool wrap;
|
bool wrap;
|
||||||
bool draw_tabs;
|
bool draw_tabs;
|
||||||
|
@ -266,6 +270,9 @@ class TextEdit : public Control {
|
||||||
|
|
||||||
int get_row_height() const;
|
int get_row_height() const;
|
||||||
|
|
||||||
|
void _reset_caret_blink_timer();
|
||||||
|
void _toggle_draw_caret();
|
||||||
|
|
||||||
void _update_caches();
|
void _update_caches();
|
||||||
void _cursor_changed_emit();
|
void _cursor_changed_emit();
|
||||||
void _text_changed_emit();
|
void _text_changed_emit();
|
||||||
|
@ -363,6 +370,12 @@ public:
|
||||||
int cursor_get_column() const;
|
int cursor_get_column() const;
|
||||||
int cursor_get_line() const;
|
int cursor_get_line() const;
|
||||||
|
|
||||||
|
bool cursor_get_blink_enabled() const;
|
||||||
|
void cursor_set_blink_enabled(const bool p_enabled);
|
||||||
|
|
||||||
|
float cursor_get_blink_speed() const;
|
||||||
|
void cursor_set_blink_speed(const float p_speed);
|
||||||
|
|
||||||
void set_readonly(bool p_readonly);
|
void set_readonly(bool p_readonly);
|
||||||
|
|
||||||
void set_max_chars(int p_max_chars);
|
void set_max_chars(int p_max_chars);
|
||||||
|
|
|
@ -503,6 +503,10 @@ void EditorSettings::_load_defaults(Ref<ConfigFile> p_extra_config) {
|
||||||
set("text_editor/create_signal_callbacks",true);
|
set("text_editor/create_signal_callbacks",true);
|
||||||
set("text_editor/autosave_interval_secs",0);
|
set("text_editor/autosave_interval_secs",0);
|
||||||
|
|
||||||
|
set("text_editor/caret_blink", false);
|
||||||
|
set("text_editor/caret_blink_speed", 0.65);
|
||||||
|
hints["text_editor/caret_blink_speed"]=PropertyInfo(Variant::REAL,"text_editor/caret_blink_speed",PROPERTY_HINT_RANGE,"0.1, 10, 0.1");
|
||||||
|
|
||||||
set("text_editor/font","");
|
set("text_editor/font","");
|
||||||
hints["text_editor/font"]=PropertyInfo(Variant::STRING,"text_editor/font",PROPERTY_HINT_GLOBAL_FILE,"*.fnt");
|
hints["text_editor/font"]=PropertyInfo(Variant::STRING,"text_editor/font",PROPERTY_HINT_GLOBAL_FILE,"*.fnt");
|
||||||
set("text_editor/auto_brace_complete", false);
|
set("text_editor/auto_brace_complete", false);
|
||||||
|
|
|
@ -1965,6 +1965,8 @@ void ScriptEditor::edit(const Ref<Script>& p_script) {
|
||||||
ste->get_text_edit()->set_show_line_numbers(EditorSettings::get_singleton()->get("text_editor/show_line_numbers"));
|
ste->get_text_edit()->set_show_line_numbers(EditorSettings::get_singleton()->get("text_editor/show_line_numbers"));
|
||||||
ste->get_text_edit()->set_syntax_coloring(EditorSettings::get_singleton()->get("text_editor/syntax_highlighting"));
|
ste->get_text_edit()->set_syntax_coloring(EditorSettings::get_singleton()->get("text_editor/syntax_highlighting"));
|
||||||
ste->get_text_edit()->set_highlight_all_occurrences(EditorSettings::get_singleton()->get("text_editor/highlight_all_occurrences"));
|
ste->get_text_edit()->set_highlight_all_occurrences(EditorSettings::get_singleton()->get("text_editor/highlight_all_occurrences"));
|
||||||
|
ste->get_text_edit()->cursor_set_blink_enabled(EditorSettings::get_singleton()->get("text_editor/caret_blink"));
|
||||||
|
ste->get_text_edit()->cursor_set_blink_speed(EditorSettings::get_singleton()->get("text_editor/caret_blink_speed"));
|
||||||
ste->get_text_edit()->set_callhint_settings(
|
ste->get_text_edit()->set_callhint_settings(
|
||||||
EditorSettings::get_singleton()->get("text_editor/put_callhint_tooltip_below_current_line"),
|
EditorSettings::get_singleton()->get("text_editor/put_callhint_tooltip_below_current_line"),
|
||||||
EditorSettings::get_singleton()->get("text_editor/callhint_tooltip_offset"));
|
EditorSettings::get_singleton()->get("text_editor/callhint_tooltip_offset"));
|
||||||
|
@ -2112,6 +2114,8 @@ void ScriptEditor::_editor_settings_changed() {
|
||||||
ste->get_text_edit()->set_show_line_numbers(EditorSettings::get_singleton()->get("text_editor/show_line_numbers"));
|
ste->get_text_edit()->set_show_line_numbers(EditorSettings::get_singleton()->get("text_editor/show_line_numbers"));
|
||||||
ste->get_text_edit()->set_syntax_coloring(EditorSettings::get_singleton()->get("text_editor/syntax_highlighting"));
|
ste->get_text_edit()->set_syntax_coloring(EditorSettings::get_singleton()->get("text_editor/syntax_highlighting"));
|
||||||
ste->get_text_edit()->set_highlight_all_occurrences(EditorSettings::get_singleton()->get("text_editor/highlight_all_occurrences"));
|
ste->get_text_edit()->set_highlight_all_occurrences(EditorSettings::get_singleton()->get("text_editor/highlight_all_occurrences"));
|
||||||
|
ste->get_text_edit()->cursor_set_blink_enabled(EditorSettings::get_singleton()->get("text_editor/caret_blink"));
|
||||||
|
ste->get_text_edit()->cursor_set_blink_speed(EditorSettings::get_singleton()->get("text_editor/caret_blink_speed"));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -368,6 +368,8 @@ void ShaderEditor::_editor_settings_changed() {
|
||||||
vertex_editor->get_text_edit()->set_show_line_numbers(EditorSettings::get_singleton()->get("text_editor/show_line_numbers"));
|
vertex_editor->get_text_edit()->set_show_line_numbers(EditorSettings::get_singleton()->get("text_editor/show_line_numbers"));
|
||||||
vertex_editor->get_text_edit()->set_syntax_coloring(EditorSettings::get_singleton()->get("text_editor/syntax_highlighting"));
|
vertex_editor->get_text_edit()->set_syntax_coloring(EditorSettings::get_singleton()->get("text_editor/syntax_highlighting"));
|
||||||
vertex_editor->get_text_edit()->set_highlight_all_occurrences(EditorSettings::get_singleton()->get("text_editor/highlight_all_occurrences"));
|
vertex_editor->get_text_edit()->set_highlight_all_occurrences(EditorSettings::get_singleton()->get("text_editor/highlight_all_occurrences"));
|
||||||
|
vertex_editor->get_text_edit()->cursor_set_blink_enabled(EditorSettings::get_singleton()->get("text_editor/caret_blink"));
|
||||||
|
vertex_editor->get_text_edit()->cursor_set_blink_speed(EditorSettings::get_singleton()->get("text_editor/caret_blink_speed"));
|
||||||
|
|
||||||
fragment_editor->get_text_edit()->set_auto_brace_completion(EditorSettings::get_singleton()->get("text_editor/auto_brace_complete"));
|
fragment_editor->get_text_edit()->set_auto_brace_completion(EditorSettings::get_singleton()->get("text_editor/auto_brace_complete"));
|
||||||
fragment_editor->get_text_edit()->set_scroll_pass_end_of_file(EditorSettings::get_singleton()->get("text_editor/scroll_past_end_of_file"));
|
fragment_editor->get_text_edit()->set_scroll_pass_end_of_file(EditorSettings::get_singleton()->get("text_editor/scroll_past_end_of_file"));
|
||||||
|
@ -376,6 +378,8 @@ void ShaderEditor::_editor_settings_changed() {
|
||||||
fragment_editor->get_text_edit()->set_show_line_numbers(EditorSettings::get_singleton()->get("text_editor/show_line_numbers"));
|
fragment_editor->get_text_edit()->set_show_line_numbers(EditorSettings::get_singleton()->get("text_editor/show_line_numbers"));
|
||||||
fragment_editor->get_text_edit()->set_syntax_coloring(EditorSettings::get_singleton()->get("text_editor/syntax_highlighting"));
|
fragment_editor->get_text_edit()->set_syntax_coloring(EditorSettings::get_singleton()->get("text_editor/syntax_highlighting"));
|
||||||
fragment_editor->get_text_edit()->set_highlight_all_occurrences(EditorSettings::get_singleton()->get("text_editor/highlight_all_occurrences"));
|
fragment_editor->get_text_edit()->set_highlight_all_occurrences(EditorSettings::get_singleton()->get("text_editor/highlight_all_occurrences"));
|
||||||
|
fragment_editor->get_text_edit()->cursor_set_blink_enabled(EditorSettings::get_singleton()->get("text_editor/caret_blink"));
|
||||||
|
fragment_editor->get_text_edit()->cursor_set_blink_speed(EditorSettings::get_singleton()->get("text_editor/caret_blink_speed"));
|
||||||
|
|
||||||
light_editor->get_text_edit()->set_auto_brace_completion(EditorSettings::get_singleton()->get("text_editor/auto_brace_complete"));
|
light_editor->get_text_edit()->set_auto_brace_completion(EditorSettings::get_singleton()->get("text_editor/auto_brace_complete"));
|
||||||
light_editor->get_text_edit()->set_scroll_pass_end_of_file(EditorSettings::get_singleton()->get("text_editor/scroll_past_end_of_file"));
|
light_editor->get_text_edit()->set_scroll_pass_end_of_file(EditorSettings::get_singleton()->get("text_editor/scroll_past_end_of_file"));
|
||||||
|
@ -384,6 +388,8 @@ void ShaderEditor::_editor_settings_changed() {
|
||||||
light_editor->get_text_edit()->set_show_line_numbers(EditorSettings::get_singleton()->get("text_editor/show_line_numbers"));
|
light_editor->get_text_edit()->set_show_line_numbers(EditorSettings::get_singleton()->get("text_editor/show_line_numbers"));
|
||||||
light_editor->get_text_edit()->set_syntax_coloring(EditorSettings::get_singleton()->get("text_editor/syntax_highlighting"));
|
light_editor->get_text_edit()->set_syntax_coloring(EditorSettings::get_singleton()->get("text_editor/syntax_highlighting"));
|
||||||
light_editor->get_text_edit()->set_highlight_all_occurrences(EditorSettings::get_singleton()->get("text_editor/highlight_all_occurrences"));
|
light_editor->get_text_edit()->set_highlight_all_occurrences(EditorSettings::get_singleton()->get("text_editor/highlight_all_occurrences"));
|
||||||
|
light_editor->get_text_edit()->cursor_set_blink_enabled(EditorSettings::get_singleton()->get("text_editor/caret_blink"));
|
||||||
|
light_editor->get_text_edit()->cursor_set_blink_speed(EditorSettings::get_singleton()->get("text_editor/caret_blink_speed"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void ShaderEditor::_bind_methods() {
|
void ShaderEditor::_bind_methods() {
|
||||||
|
|
Loading…
Reference in New Issue