Add Ability to Enable/Disable Shortcuts for LineEdit/TextEdit

This PR adds the ability to enable/disable shortcut keys and selection for LineEdit/TextEdit. It also updates the context menu when you disable/enable the shortcut keys or selection.
This commit is contained in:
Emmanuel Barroga 2019-08-07 17:09:46 -07:00
parent 750f8d4926
commit b678d68224
4 changed files with 161 additions and 41 deletions

View File

@ -87,7 +87,7 @@ void LineEdit::_gui_input(Ref<InputEvent> p_event) {
} else { } else {
if (b->is_doubleclick()) { if (b->is_doubleclick() && selecting_enabled) {
selection.enabled = true; selection.enabled = true;
selection.begin = 0; selection.begin = 0;
@ -195,7 +195,7 @@ void LineEdit::_gui_input(Ref<InputEvent> p_event) {
unsigned int code = k->get_scancode(); unsigned int code = k->get_scancode();
if (k->get_command()) { if (k->get_command() && is_shortcut_keys_enabled()) {
bool handled = true; bool handled = true;
@ -210,7 +210,6 @@ void LineEdit::_gui_input(Ref<InputEvent> p_event) {
} break; } break;
case (KEY_C): { // COPY case (KEY_C): { // COPY
copy_text(); copy_text();
} break; } break;
@ -275,6 +274,7 @@ void LineEdit::_gui_input(Ref<InputEvent> p_event) {
} break; } break;
case (KEY_A): { //Select All case (KEY_A): { //Select All
select(); select();
} break; } break;
#ifdef APPLE_STYLE_KEYS #ifdef APPLE_STYLE_KEYS
case (KEY_LEFT): { // Go to start of text - like HOME key case (KEY_LEFT): { // Go to start of text - like HOME key
@ -1335,6 +1335,8 @@ int LineEdit::get_max_length() const {
} }
void LineEdit::selection_fill_at_cursor() { void LineEdit::selection_fill_at_cursor() {
if (!selecting_enabled)
return;
selection.begin = cursor_pos; selection.begin = cursor_pos;
selection.end = selection.cursor_start; selection.end = selection.cursor_start;
@ -1349,6 +1351,8 @@ void LineEdit::selection_fill_at_cursor() {
} }
void LineEdit::select_all() { void LineEdit::select_all() {
if (!selecting_enabled)
return;
if (!text.length()) if (!text.length())
return; return;
@ -1365,32 +1369,7 @@ void LineEdit::set_editable(bool p_editable) {
return; return;
editable = p_editable; editable = p_editable;
_generate_context_menu();
// Reorganize context menu.
menu->clear();
if (editable) {
menu->add_item(RTR("Undo"), MENU_UNDO, KEY_MASK_CMD | KEY_Z);
menu->add_item(RTR("Redo"), MENU_REDO, KEY_MASK_CMD | KEY_MASK_SHIFT | KEY_Z);
}
if (editable) {
menu->add_separator();
menu->add_item(RTR("Cut"), MENU_CUT, KEY_MASK_CMD | KEY_X);
}
menu->add_item(RTR("Copy"), MENU_COPY, KEY_MASK_CMD | KEY_C);
if (editable) {
menu->add_item(RTR("Paste"), MENU_PASTE, KEY_MASK_CMD | KEY_V);
}
menu->add_separator();
menu->add_item(RTR("Select All"), MENU_SELECT_ALL, KEY_MASK_CMD | KEY_A);
if (editable) {
menu->add_item(RTR("Clear"), MENU_CLEAR);
}
update(); update();
} }
@ -1426,6 +1405,8 @@ String LineEdit::get_secret_character() const {
} }
void LineEdit::select(int p_from, int p_to) { void LineEdit::select(int p_from, int p_to) {
if (!selecting_enabled)
return;
if (p_from == 0 && p_to == 0) { if (p_from == 0 && p_to == 0) {
deselect(); deselect();
@ -1533,6 +1514,29 @@ bool LineEdit::is_clear_button_enabled() const {
return clear_button_enabled; return clear_button_enabled;
} }
void LineEdit::set_shortcut_keys_enabled(bool p_enabled) {
shortcut_keys_enabled = p_enabled;
_generate_context_menu();
}
bool LineEdit::is_shortcut_keys_enabled() const {
return shortcut_keys_enabled;
}
void LineEdit::set_selecting_enabled(bool p_enabled) {
selecting_enabled = p_enabled;
if (!selecting_enabled)
deselect();
_generate_context_menu();
}
bool LineEdit::is_selecting_enabled() const {
return selecting_enabled;
}
void LineEdit::set_right_icon(const Ref<Texture> &p_icon) { void LineEdit::set_right_icon(const Ref<Texture> &p_icon) {
if (right_icon == p_icon) { if (right_icon == p_icon) {
return; return;
@ -1596,6 +1600,25 @@ void LineEdit::_create_undo_state() {
undo_stack.push_back(op); undo_stack.push_back(op);
} }
void LineEdit::_generate_context_menu() {
// Reorganize context menu.
menu->clear();
if (editable)
menu->add_item(RTR("Cut"), MENU_CUT, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_X : 0);
menu->add_item(RTR("Copy"), MENU_COPY, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_C : 0);
if (editable)
menu->add_item(RTR("Paste"), MENU_PASTE, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_V : 0);
menu->add_separator();
if (is_selecting_enabled())
menu->add_item(RTR("Select All"), MENU_SELECT_ALL, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_A : 0);
if (editable) {
menu->add_item(RTR("Clear"), MENU_CLEAR);
menu->add_separator();
menu->add_item(RTR("Undo"), MENU_UNDO, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_Z : 0);
menu->add_item(RTR("Redo"), MENU_REDO, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_MASK_SHIFT | KEY_Z : 0);
}
}
void LineEdit::_bind_methods() { void LineEdit::_bind_methods() {
ClassDB::bind_method(D_METHOD("_text_changed"), &LineEdit::_text_changed); ClassDB::bind_method(D_METHOD("_text_changed"), &LineEdit::_text_changed);
@ -1640,6 +1663,10 @@ void LineEdit::_bind_methods() {
ClassDB::bind_method(D_METHOD("is_context_menu_enabled"), &LineEdit::is_context_menu_enabled); ClassDB::bind_method(D_METHOD("is_context_menu_enabled"), &LineEdit::is_context_menu_enabled);
ClassDB::bind_method(D_METHOD("set_clear_button_enabled", "enable"), &LineEdit::set_clear_button_enabled); ClassDB::bind_method(D_METHOD("set_clear_button_enabled", "enable"), &LineEdit::set_clear_button_enabled);
ClassDB::bind_method(D_METHOD("is_clear_button_enabled"), &LineEdit::is_clear_button_enabled); ClassDB::bind_method(D_METHOD("is_clear_button_enabled"), &LineEdit::is_clear_button_enabled);
ClassDB::bind_method(D_METHOD("set_shortcut_keys_enabled", "enable"), &LineEdit::set_shortcut_keys_enabled);
ClassDB::bind_method(D_METHOD("is_shortcut_keys_enabled"), &LineEdit::is_shortcut_keys_enabled);
ClassDB::bind_method(D_METHOD("set_selecting_enabled", "enable"), &LineEdit::set_selecting_enabled);
ClassDB::bind_method(D_METHOD("is_selecting_enabled"), &LineEdit::is_selecting_enabled);
ADD_SIGNAL(MethodInfo("text_changed", PropertyInfo(Variant::STRING, "new_text"))); ADD_SIGNAL(MethodInfo("text_changed", PropertyInfo(Variant::STRING, "new_text")));
ADD_SIGNAL(MethodInfo("text_entered", PropertyInfo(Variant::STRING, "new_text"))); ADD_SIGNAL(MethodInfo("text_entered", PropertyInfo(Variant::STRING, "new_text")));
@ -1668,6 +1695,8 @@ void LineEdit::_bind_methods() {
ADD_PROPERTY(PropertyInfo(Variant::INT, "focus_mode", PROPERTY_HINT_ENUM, "None,Click,All"), "set_focus_mode", "get_focus_mode"); ADD_PROPERTY(PropertyInfo(Variant::INT, "focus_mode", PROPERTY_HINT_ENUM, "None,Click,All"), "set_focus_mode", "get_focus_mode");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "context_menu_enabled"), "set_context_menu_enabled", "is_context_menu_enabled"); ADD_PROPERTY(PropertyInfo(Variant::BOOL, "context_menu_enabled"), "set_context_menu_enabled", "is_context_menu_enabled");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "clear_button_enabled"), "set_clear_button_enabled", "is_clear_button_enabled"); ADD_PROPERTY(PropertyInfo(Variant::BOOL, "clear_button_enabled"), "set_clear_button_enabled", "is_clear_button_enabled");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "shortcut_keys_enabled"), "set_shortcut_keys_enabled", "is_shortcut_keys_enabled");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "selecting_enabled"), "set_selecting_enabled", "is_selecting_enabled");
ADD_GROUP("Placeholder", "placeholder_"); ADD_GROUP("Placeholder", "placeholder_");
ADD_PROPERTY(PropertyInfo(Variant::STRING, "placeholder_text"), "set_placeholder", "get_placeholder"); ADD_PROPERTY(PropertyInfo(Variant::STRING, "placeholder_text"), "set_placeholder", "get_placeholder");
ADD_PROPERTY(PropertyInfo(Variant::REAL, "placeholder_alpha", PROPERTY_HINT_RANGE, "0,1,0.001"), "set_placeholder_alpha", "get_placeholder_alpha"); ADD_PROPERTY(PropertyInfo(Variant::REAL, "placeholder_alpha", PROPERTY_HINT_RANGE, "0,1,0.001"), "set_placeholder_alpha", "get_placeholder_alpha");
@ -1695,6 +1724,8 @@ LineEdit::LineEdit() {
clear_button_enabled = false; clear_button_enabled = false;
clear_button_status.press_attempt = false; clear_button_status.press_attempt = false;
clear_button_status.pressing_inside = false; clear_button_status.pressing_inside = false;
shortcut_keys_enabled = true;
selecting_enabled = true;
deselect(); deselect();
set_focus_mode(FOCUS_ALL); set_focus_mode(FOCUS_ALL);

View File

@ -75,6 +75,8 @@ private:
String ime_text; String ime_text;
Point2 ime_selection; Point2 ime_selection;
bool selecting_enabled;
bool context_menu_enabled; bool context_menu_enabled;
PopupMenu *menu; PopupMenu *menu;
@ -87,6 +89,8 @@ private:
bool clear_button_enabled; bool clear_button_enabled;
bool shortcut_keys_enabled;
Ref<Texture> right_icon; Ref<Texture> right_icon;
struct Selection { struct Selection {
@ -118,6 +122,8 @@ private:
void _clear_redo(); void _clear_redo();
void _create_undo_state(); void _create_undo_state();
void _generate_context_menu();
Timer *caret_blink_timer; Timer *caret_blink_timer;
void _text_changed(); void _text_changed();
@ -216,6 +222,12 @@ public:
void set_clear_button_enabled(bool p_enabled); void set_clear_button_enabled(bool p_enabled);
bool is_clear_button_enabled() const; bool is_clear_button_enabled() const;
void set_shortcut_keys_enabled(bool p_enabled);
bool is_shortcut_keys_enabled() const;
void set_selecting_enabled(bool p_enabled);
bool is_selecting_enabled() const;
void set_right_icon(const Ref<Texture> &p_icon); void set_right_icon(const Ref<Texture> &p_icon);
virtual bool is_text_field() const; virtual bool is_text_field() const;

View File

@ -3216,7 +3216,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
if (readonly) if (readonly)
break; break;
if (k->get_shift() && !k->get_command() && !k->get_alt()) { if (k->get_shift() && !k->get_command() && !k->get_alt() && is_shortcut_keys_enabled()) {
cut(); cut();
break; break;
} }
@ -3447,13 +3447,15 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
scancode_handled = false; scancode_handled = false;
break; break;
} }
select_all(); if (is_shortcut_keys_enabled()) {
select_all();
}
#else #else
if ((!k->get_command() && !k->get_control())) { if ((!k->get_command() && !k->get_control())) {
scancode_handled = false; scancode_handled = false;
break; break;
} }
if (!k->get_shift() && k->get_command()) if (!k->get_shift() && k->get_command() && is_shortcut_keys_enabled())
select_all(); select_all();
else if (k->get_control()) { else if (k->get_control()) {
if (k->get_shift()) if (k->get_shift())
@ -3509,8 +3511,9 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
scancode_handled = false; scancode_handled = false;
break; break;
} }
if (is_shortcut_keys_enabled()) {
cut(); cut();
}
} break; } break;
case KEY_C: { case KEY_C: {
@ -3520,7 +3523,9 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
break; break;
} }
copy(); if (is_shortcut_keys_enabled()) {
copy();
}
} break; } break;
case KEY_Z: { case KEY_Z: {
@ -3534,10 +3539,12 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
break; break;
} }
if (k->get_shift()) if (is_shortcut_keys_enabled()) {
redo(); if (k->get_shift())
else redo();
undo(); else
undo();
}
} break; } break;
case KEY_Y: { case KEY_Y: {
@ -3550,7 +3557,9 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
break; break;
} }
redo(); if (is_shortcut_keys_enabled()) {
redo();
}
} break; } break;
case KEY_V: { case KEY_V: {
if (readonly) { if (readonly) {
@ -3561,7 +3570,9 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
break; break;
} }
paste(); if (is_shortcut_keys_enabled()) {
paste();
}
} break; } break;
case KEY_SPACE: { case KEY_SPACE: {
@ -4055,6 +4066,25 @@ int TextEdit::_get_control_height() const {
return control_height; return control_height;
} }
void TextEdit::_generate_context_menu() {
// Reorganize context menu.
menu->clear();
if (!readonly)
menu->add_item(RTR("Cut"), MENU_CUT, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_X : 0);
menu->add_item(RTR("Copy"), MENU_COPY, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_C : 0);
if (!readonly)
menu->add_item(RTR("Paste"), MENU_PASTE, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_V : 0);
menu->add_separator();
if (is_selecting_enabled())
menu->add_item(RTR("Select All"), MENU_SELECT_ALL, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_A : 0);
if (!readonly) {
menu->add_item(RTR("Clear"), MENU_CLEAR);
menu->add_separator();
menu->add_item(RTR("Undo"), MENU_UNDO, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_Z : 0);
menu->add_item(RTR("Redo"), MENU_REDO, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_MASK_SHIFT | KEY_Z : 0);
}
}
int TextEdit::get_visible_rows() const { int TextEdit::get_visible_rows() const {
return _get_control_height() / get_row_height(); return _get_control_height() / get_row_height();
} }
@ -4760,6 +4790,7 @@ void TextEdit::set_readonly(bool p_readonly) {
return; return;
readonly = p_readonly; readonly = p_readonly;
_generate_context_menu();
// Reorganize context menu. // Reorganize context menu.
menu->clear(); menu->clear();
@ -5097,6 +5128,8 @@ void TextEdit::paste() {
} }
void TextEdit::select_all() { void TextEdit::select_all() {
if (!selecting_enabled)
return;
if (text.size() == 1 && text[0].length() == 0) if (text.size() == 1 && text[0].length() == 0)
return; return;
@ -5121,6 +5154,8 @@ void TextEdit::deselect() {
} }
void TextEdit::select(int p_from_line, int p_from_column, int p_to_line, int p_to_column) { void TextEdit::select(int p_from_line, int p_from_column, int p_to_line, int p_to_column) {
if (!selecting_enabled)
return;
if (p_from_line < 0) if (p_from_line < 0)
p_from_line = 0; p_from_line = 0;
@ -6764,6 +6799,29 @@ bool TextEdit::is_context_menu_enabled() {
return context_menu_enabled; return context_menu_enabled;
} }
void TextEdit::set_shortcut_keys_enabled(bool p_enabled) {
shortcut_keys_enabled = p_enabled;
_generate_context_menu();
}
void TextEdit::set_selecting_enabled(bool p_enabled) {
selecting_enabled = p_enabled;
if (!selecting_enabled)
deselect();
_generate_context_menu();
}
bool TextEdit::is_selecting_enabled() const {
return selecting_enabled;
}
bool TextEdit::is_shortcut_keys_enabled() const {
return shortcut_keys_enabled;
}
PopupMenu *TextEdit::get_menu() const { PopupMenu *TextEdit::get_menu() const {
return menu; return menu;
} }
@ -6819,6 +6877,10 @@ void TextEdit::_bind_methods() {
ClassDB::bind_method(D_METHOD("is_wrap_enabled"), &TextEdit::is_wrap_enabled); ClassDB::bind_method(D_METHOD("is_wrap_enabled"), &TextEdit::is_wrap_enabled);
ClassDB::bind_method(D_METHOD("set_context_menu_enabled", "enable"), &TextEdit::set_context_menu_enabled); ClassDB::bind_method(D_METHOD("set_context_menu_enabled", "enable"), &TextEdit::set_context_menu_enabled);
ClassDB::bind_method(D_METHOD("is_context_menu_enabled"), &TextEdit::is_context_menu_enabled); ClassDB::bind_method(D_METHOD("is_context_menu_enabled"), &TextEdit::is_context_menu_enabled);
ClassDB::bind_method(D_METHOD("set_shortcut_keys_enabled", "enable"), &TextEdit::set_shortcut_keys_enabled);
ClassDB::bind_method(D_METHOD("is_shortcut_keys_enabled"), &TextEdit::is_shortcut_keys_enabled);
ClassDB::bind_method(D_METHOD("set_selecting_enabled", "enable"), &TextEdit::set_selecting_enabled);
ClassDB::bind_method(D_METHOD("is_selecting_enabled"), &TextEdit::is_selecting_enabled);
ClassDB::bind_method(D_METHOD("cut"), &TextEdit::cut); ClassDB::bind_method(D_METHOD("cut"), &TextEdit::cut);
ClassDB::bind_method(D_METHOD("copy"), &TextEdit::copy); ClassDB::bind_method(D_METHOD("copy"), &TextEdit::copy);
@ -6909,6 +6971,8 @@ void TextEdit::_bind_methods() {
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "highlight_all_occurrences"), "set_highlight_all_occurrences", "is_highlight_all_occurrences_enabled"); ADD_PROPERTY(PropertyInfo(Variant::BOOL, "highlight_all_occurrences"), "set_highlight_all_occurrences", "is_highlight_all_occurrences_enabled");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "override_selected_font_color"), "set_override_selected_font_color", "is_overriding_selected_font_color"); ADD_PROPERTY(PropertyInfo(Variant::BOOL, "override_selected_font_color"), "set_override_selected_font_color", "is_overriding_selected_font_color");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "context_menu_enabled"), "set_context_menu_enabled", "is_context_menu_enabled"); ADD_PROPERTY(PropertyInfo(Variant::BOOL, "context_menu_enabled"), "set_context_menu_enabled", "is_context_menu_enabled");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "shortcut_keys_enabled"), "set_shortcut_keys_enabled", "is_shortcut_keys_enabled");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "selecting_enabled"), "set_selecting_enabled", "is_selecting_enabled");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "smooth_scrolling"), "set_smooth_scroll_enable", "is_smooth_scroll_enabled"); ADD_PROPERTY(PropertyInfo(Variant::BOOL, "smooth_scrolling"), "set_smooth_scroll_enable", "is_smooth_scroll_enabled");
ADD_PROPERTY(PropertyInfo(Variant::REAL, "v_scroll_speed"), "set_v_scroll_speed", "get_v_scroll_speed"); ADD_PROPERTY(PropertyInfo(Variant::REAL, "v_scroll_speed"), "set_v_scroll_speed", "get_v_scroll_speed");
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "hiding_enabled"), "set_hiding_enabled", "is_hiding_enabled"); ADD_PROPERTY(PropertyInfo(Variant::BOOL, "hiding_enabled"), "set_hiding_enabled", "is_hiding_enabled");
@ -7067,7 +7131,9 @@ TextEdit::TextEdit() {
minimap_char_size = Point2(1, 2); minimap_char_size = Point2(1, 2);
minimap_line_spacing = 1; minimap_line_spacing = 1;
selecting_enabled = true;
context_menu_enabled = true; context_menu_enabled = true;
shortcut_keys_enabled = true;
menu = memnew(PopupMenu); menu = memnew(PopupMenu);
add_child(menu); add_child(menu);
readonly = true; // Initialise to opposite first, so we get past the early-out in set_readonly. readonly = true; // Initialise to opposite first, so we get past the early-out in set_readonly.

View File

@ -365,10 +365,15 @@ private:
int search_result_line; int search_result_line;
int search_result_col; int search_result_col;
bool selecting_enabled;
bool context_menu_enabled; bool context_menu_enabled;
bool shortcut_keys_enabled;
int executing_line; int executing_line;
void _generate_context_menu();
int get_visible_rows() const; int get_visible_rows() const;
int get_total_visible_rows() const; int get_total_visible_rows() const;
@ -737,6 +742,12 @@ public:
void set_context_menu_enabled(bool p_enable); void set_context_menu_enabled(bool p_enable);
bool is_context_menu_enabled(); bool is_context_menu_enabled();
void set_selecting_enabled(bool p_enabled);
bool is_selecting_enabled() const;
void set_shortcut_keys_enabled(bool p_enabled);
bool is_shortcut_keys_enabled() const;
PopupMenu *get_menu() const; PopupMenu *get_menu() const;
String get_text_for_completion(); String get_text_for_completion();