Skip to content

Commit

Permalink
Merge pull request #51498 from codecat/fix-triple-click
Browse files Browse the repository at this point in the history
Triple click in text editor now uses last mouse position for validity
  • Loading branch information
akien-mga committed Aug 11, 2021
2 parents 18fb585 + 408401a commit 7188cb6
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 1 deletion.
6 changes: 5 additions & 1 deletion scene/gui/text_edit.cpp
Expand Up @@ -2246,7 +2246,10 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
selection.selecting_column = col;
}

if (!mb->is_double_click() && (OS::get_singleton()->get_ticks_msec() - last_dblclk) < 600 && cursor.line == prev_line) {
const int triple_click_timeout = 600;
const int triple_click_tolerance = 5;

if (!mb->is_double_click() && (OS::get_singleton()->get_ticks_msec() - last_dblclk) < triple_click_timeout && mb->get_position().distance_to(last_dblclk_pos) < triple_click_tolerance) {
// Triple-click select line.
selection.selecting_mode = SelectionMode::SELECTION_MODE_LINE;
_update_selection_mode_line();
Expand All @@ -2256,6 +2259,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
selection.selecting_mode = SelectionMode::SELECTION_MODE_WORD;
_update_selection_mode_word();
last_dblclk = OS::get_singleton()->get_ticks_msec();
last_dblclk_pos = mb->get_position();
}

update();
Expand Down
1 change: 1 addition & 0 deletions scene/gui/text_edit.h
Expand Up @@ -308,6 +308,7 @@ class TextEdit : public Control {
String lookup_symbol_word;

uint64_t last_dblclk = 0;
Vector2 last_dblclk_pos;

Timer *idle_detect;
Timer *click_select_held;
Expand Down

0 comments on commit 7188cb6

Please sign in to comment.