1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639 |
- :github_url: hide
- .. DO NOT EDIT THIS FILE!!!
- .. Generated automatically from Godot engine sources.
- .. Generator: https://github.com/godotengine/godot/tree/master/doc/tools/make_rst.py.
- .. XML source: https://github.com/godotengine/godot/tree/master/doc/classes/LineEdit.xml.
- .. _class_LineEdit:
- LineEdit
- ========
- **Inherits:** :ref:`Control<class_Control>` **<** :ref:`CanvasItem<class_CanvasItem>` **<** :ref:`Node<class_Node>` **<** :ref:`Object<class_Object>`
- An input field for single-line text.
- .. rst-class:: classref-introduction-group
- Description
- -----------
- **LineEdit** provides an input field for editing a single line of text. It features many built-in shortcuts that are always available (:kbd:`Ctrl` here maps to :kbd:`Cmd` on macOS):
- - :kbd:`Ctrl + C`: Copy
- - :kbd:`Ctrl + X`: Cut
- - :kbd:`Ctrl + V` or :kbd:`Ctrl + Y`: Paste/"yank"
- - :kbd:`Ctrl + Z`: Undo
- - :kbd:`Ctrl + ~`: Swap input direction.
- - :kbd:`Ctrl + Shift + Z`: Redo
- - :kbd:`Ctrl + U`: Delete text from the caret position to the beginning of the line
- - :kbd:`Ctrl + K`: Delete text from the caret position to the end of the line
- - :kbd:`Ctrl + A`: Select all text
- - :kbd:`Up Arrow`/:kbd:`Down Arrow`: Move the caret to the beginning/end of the line
- On macOS, some extra keyboard shortcuts are available:
- - :kbd:`Cmd + F`: Same as :kbd:`Right Arrow`, move the caret one character right
- - :kbd:`Cmd + B`: Same as :kbd:`Left Arrow`, move the caret one character left
- - :kbd:`Cmd + P`: Same as :kbd:`Up Arrow`, move the caret to the previous line
- - :kbd:`Cmd + N`: Same as :kbd:`Down Arrow`, move the caret to the next line
- - :kbd:`Cmd + D`: Same as :kbd:`Delete`, delete the character on the right side of caret
- - :kbd:`Cmd + H`: Same as :kbd:`Backspace`, delete the character on the left side of the caret
- - :kbd:`Cmd + A`: Same as :kbd:`Home`, move the caret to the beginning of the line
- - :kbd:`Cmd + E`: Same as :kbd:`End`, move the caret to the end of the line
- - :kbd:`Cmd + Left Arrow`: Same as :kbd:`Home`, move the caret to the beginning of the line
- - :kbd:`Cmd + Right Arrow`: Same as :kbd:`End`, move the caret to the end of the line
- .. rst-class:: classref-reftable-group
- Properties
- ----------
- .. table::
- :widths: auto
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`HorizontalAlignment<enum_@GlobalScope_HorizontalAlignment>` | :ref:`alignment<class_LineEdit_property_alignment>` | ``0`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`caret_blink<class_LineEdit_property_caret_blink>` | ``false`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`float<class_float>` | :ref:`caret_blink_interval<class_LineEdit_property_caret_blink_interval>` | ``0.65`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`int<class_int>` | :ref:`caret_column<class_LineEdit_property_caret_column>` | ``0`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`caret_force_displayed<class_LineEdit_property_caret_force_displayed>` | ``false`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`caret_mid_grapheme<class_LineEdit_property_caret_mid_grapheme>` | ``false`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`clear_button_enabled<class_LineEdit_property_clear_button_enabled>` | ``false`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`context_menu_enabled<class_LineEdit_property_context_menu_enabled>` | ``true`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`deselect_on_focus_loss_enabled<class_LineEdit_property_deselect_on_focus_loss_enabled>` | ``true`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`drag_and_drop_selection_enabled<class_LineEdit_property_drag_and_drop_selection_enabled>` | ``true`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`draw_control_chars<class_LineEdit_property_draw_control_chars>` | ``false`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`editable<class_LineEdit_property_editable>` | ``true`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`expand_to_text_length<class_LineEdit_property_expand_to_text_length>` | ``false`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`flat<class_LineEdit_property_flat>` | ``false`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`FocusMode<enum_Control_FocusMode>` | focus_mode | ``2`` (overrides :ref:`Control<class_Control_property_focus_mode>`) |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`String<class_String>` | :ref:`language<class_LineEdit_property_language>` | ``""`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`int<class_int>` | :ref:`max_length<class_LineEdit_property_max_length>` | ``0`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`middle_mouse_paste_enabled<class_LineEdit_property_middle_mouse_paste_enabled>` | ``true`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`CursorShape<enum_Control_CursorShape>` | mouse_default_cursor_shape | ``1`` (overrides :ref:`Control<class_Control_property_mouse_default_cursor_shape>`) |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`String<class_String>` | :ref:`placeholder_text<class_LineEdit_property_placeholder_text>` | ``""`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`Texture2D<class_Texture2D>` | :ref:`right_icon<class_LineEdit_property_right_icon>` | |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`secret<class_LineEdit_property_secret>` | ``false`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`String<class_String>` | :ref:`secret_character<class_LineEdit_property_secret_character>` | ``"•"`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`select_all_on_focus<class_LineEdit_property_select_all_on_focus>` | ``false`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`selecting_enabled<class_LineEdit_property_selecting_enabled>` | ``true`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`shortcut_keys_enabled<class_LineEdit_property_shortcut_keys_enabled>` | ``true`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`StructuredTextParser<enum_TextServer_StructuredTextParser>` | :ref:`structured_text_bidi_override<class_LineEdit_property_structured_text_bidi_override>` | ``0`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`Array<class_Array>` | :ref:`structured_text_bidi_override_options<class_LineEdit_property_structured_text_bidi_override_options>` | ``[]`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`String<class_String>` | :ref:`text<class_LineEdit_property_text>` | ``""`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`TextDirection<enum_Control_TextDirection>` | :ref:`text_direction<class_LineEdit_property_text_direction>` | ``0`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`virtual_keyboard_enabled<class_LineEdit_property_virtual_keyboard_enabled>` | ``true`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- | :ref:`VirtualKeyboardType<enum_LineEdit_VirtualKeyboardType>` | :ref:`virtual_keyboard_type<class_LineEdit_property_virtual_keyboard_type>` | ``0`` |
- +-------------------------------------------------------------------+-------------------------------------------------------------------------------------------------------------+-------------------------------------------------------------------------------------+
- .. rst-class:: classref-reftable-group
- Methods
- -------
- .. table::
- :widths: auto
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`clear<class_LineEdit_method_clear>` **(** **)** |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`delete_char_at_caret<class_LineEdit_method_delete_char_at_caret>` **(** **)** |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`delete_text<class_LineEdit_method_delete_text>` **(** :ref:`int<class_int>` from_column, :ref:`int<class_int>` to_column **)** |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`deselect<class_LineEdit_method_deselect>` **(** **)** |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`PopupMenu<class_PopupMenu>` | :ref:`get_menu<class_LineEdit_method_get_menu>` **(** **)** |const| |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`float<class_float>` | :ref:`get_scroll_offset<class_LineEdit_method_get_scroll_offset>` **(** **)** |const| |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`String<class_String>` | :ref:`get_selected_text<class_LineEdit_method_get_selected_text>` **(** **)** |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`int<class_int>` | :ref:`get_selection_from_column<class_LineEdit_method_get_selection_from_column>` **(** **)** |const| |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`int<class_int>` | :ref:`get_selection_to_column<class_LineEdit_method_get_selection_to_column>` **(** **)** |const| |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`has_selection<class_LineEdit_method_has_selection>` **(** **)** |const| |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`insert_text_at_caret<class_LineEdit_method_insert_text_at_caret>` **(** :ref:`String<class_String>` text **)** |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | :ref:`bool<class_bool>` | :ref:`is_menu_visible<class_LineEdit_method_is_menu_visible>` **(** **)** |const| |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`menu_option<class_LineEdit_method_menu_option>` **(** :ref:`int<class_int>` option **)** |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`select<class_LineEdit_method_select>` **(** :ref:`int<class_int>` from=0, :ref:`int<class_int>` to=-1 **)** |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- | void | :ref:`select_all<class_LineEdit_method_select_all>` **(** **)** |
- +-----------------------------------+--------------------------------------------------------------------------------------------------------------------------------------+
- .. rst-class:: classref-reftable-group
- Theme Properties
- ----------------
- .. table::
- :widths: auto
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`Color<class_Color>` | :ref:`caret_color<class_LineEdit_theme_color_caret_color>` | ``Color(0.95, 0.95, 0.95, 1)`` |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`Color<class_Color>` | :ref:`clear_button_color<class_LineEdit_theme_color_clear_button_color>` | ``Color(0.875, 0.875, 0.875, 1)`` |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`Color<class_Color>` | :ref:`clear_button_color_pressed<class_LineEdit_theme_color_clear_button_color_pressed>` | ``Color(1, 1, 1, 1)`` |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`Color<class_Color>` | :ref:`font_color<class_LineEdit_theme_color_font_color>` | ``Color(0.875, 0.875, 0.875, 1)`` |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`Color<class_Color>` | :ref:`font_outline_color<class_LineEdit_theme_color_font_outline_color>` | ``Color(1, 1, 1, 1)`` |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`Color<class_Color>` | :ref:`font_placeholder_color<class_LineEdit_theme_color_font_placeholder_color>` | ``Color(0.875, 0.875, 0.875, 0.6)`` |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`Color<class_Color>` | :ref:`font_selected_color<class_LineEdit_theme_color_font_selected_color>` | ``Color(1, 1, 1, 1)`` |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`Color<class_Color>` | :ref:`font_uneditable_color<class_LineEdit_theme_color_font_uneditable_color>` | ``Color(0.875, 0.875, 0.875, 0.5)`` |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`Color<class_Color>` | :ref:`selection_color<class_LineEdit_theme_color_selection_color>` | ``Color(0.5, 0.5, 0.5, 1)`` |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`int<class_int>` | :ref:`caret_width<class_LineEdit_theme_constant_caret_width>` | ``1`` |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`int<class_int>` | :ref:`minimum_character_width<class_LineEdit_theme_constant_minimum_character_width>` | ``4`` |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`int<class_int>` | :ref:`outline_size<class_LineEdit_theme_constant_outline_size>` | ``0`` |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`Font<class_Font>` | :ref:`font<class_LineEdit_theme_font_font>` | |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`int<class_int>` | :ref:`font_size<class_LineEdit_theme_font_size_font_size>` | |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`Texture2D<class_Texture2D>` | :ref:`clear<class_LineEdit_theme_icon_clear>` | |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`StyleBox<class_StyleBox>` | :ref:`focus<class_LineEdit_theme_style_focus>` | |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`StyleBox<class_StyleBox>` | :ref:`normal<class_LineEdit_theme_style_normal>` | |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- | :ref:`StyleBox<class_StyleBox>` | :ref:`read_only<class_LineEdit_theme_style_read_only>` | |
- +-----------------------------------+------------------------------------------------------------------------------------------+-------------------------------------+
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Signals
- -------
- .. _class_LineEdit_signal_text_change_rejected:
- .. rst-class:: classref-signal
- **text_change_rejected** **(** :ref:`String<class_String>` rejected_substring **)**
- Emitted when appending text that overflows the :ref:`max_length<class_LineEdit_property_max_length>`. The appended text is truncated to fit :ref:`max_length<class_LineEdit_property_max_length>`, and the part that couldn't fit is passed as the ``rejected_substring`` argument.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_signal_text_changed:
- .. rst-class:: classref-signal
- **text_changed** **(** :ref:`String<class_String>` new_text **)**
- Emitted when the text changes.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_signal_text_submitted:
- .. rst-class:: classref-signal
- **text_submitted** **(** :ref:`String<class_String>` new_text **)**
- Emitted when the user presses :ref:`@GlobalScope.KEY_ENTER<class_@GlobalScope_constant_KEY_ENTER>` on the **LineEdit**.
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Enumerations
- ------------
- .. _enum_LineEdit_MenuItems:
- .. rst-class:: classref-enumeration
- enum **MenuItems**:
- .. _class_LineEdit_constant_MENU_CUT:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_CUT** = ``0``
- Cuts (copies and clears) the selected text.
- .. _class_LineEdit_constant_MENU_COPY:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_COPY** = ``1``
- Copies the selected text.
- .. _class_LineEdit_constant_MENU_PASTE:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_PASTE** = ``2``
- Pastes the clipboard text over the selected text (or at the caret's position).
- Non-printable escape characters are automatically stripped from the OS clipboard via :ref:`String.strip_escapes<class_String_method_strip_escapes>`.
- .. _class_LineEdit_constant_MENU_CLEAR:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_CLEAR** = ``3``
- Erases the whole **LineEdit** text.
- .. _class_LineEdit_constant_MENU_SELECT_ALL:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_SELECT_ALL** = ``4``
- Selects the whole **LineEdit** text.
- .. _class_LineEdit_constant_MENU_UNDO:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_UNDO** = ``5``
- Undoes the previous action.
- .. _class_LineEdit_constant_MENU_REDO:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_REDO** = ``6``
- Reverse the last undo action.
- .. _class_LineEdit_constant_MENU_SUBMENU_TEXT_DIR:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_SUBMENU_TEXT_DIR** = ``7``
- ID of "Text Writing Direction" submenu.
- .. _class_LineEdit_constant_MENU_DIR_INHERITED:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_DIR_INHERITED** = ``8``
- Sets text direction to inherited.
- .. _class_LineEdit_constant_MENU_DIR_AUTO:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_DIR_AUTO** = ``9``
- Sets text direction to automatic.
- .. _class_LineEdit_constant_MENU_DIR_LTR:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_DIR_LTR** = ``10``
- Sets text direction to left-to-right.
- .. _class_LineEdit_constant_MENU_DIR_RTL:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_DIR_RTL** = ``11``
- Sets text direction to right-to-left.
- .. _class_LineEdit_constant_MENU_DISPLAY_UCC:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_DISPLAY_UCC** = ``12``
- Toggles control character display.
- .. _class_LineEdit_constant_MENU_SUBMENU_INSERT_UCC:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_SUBMENU_INSERT_UCC** = ``13``
- ID of "Insert Control Character" submenu.
- .. _class_LineEdit_constant_MENU_INSERT_LRM:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_LRM** = ``14``
- Inserts left-to-right mark (LRM) character.
- .. _class_LineEdit_constant_MENU_INSERT_RLM:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_RLM** = ``15``
- Inserts right-to-left mark (RLM) character.
- .. _class_LineEdit_constant_MENU_INSERT_LRE:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_LRE** = ``16``
- Inserts start of left-to-right embedding (LRE) character.
- .. _class_LineEdit_constant_MENU_INSERT_RLE:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_RLE** = ``17``
- Inserts start of right-to-left embedding (RLE) character.
- .. _class_LineEdit_constant_MENU_INSERT_LRO:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_LRO** = ``18``
- Inserts start of left-to-right override (LRO) character.
- .. _class_LineEdit_constant_MENU_INSERT_RLO:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_RLO** = ``19``
- Inserts start of right-to-left override (RLO) character.
- .. _class_LineEdit_constant_MENU_INSERT_PDF:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_PDF** = ``20``
- Inserts pop direction formatting (PDF) character.
- .. _class_LineEdit_constant_MENU_INSERT_ALM:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_ALM** = ``21``
- Inserts Arabic letter mark (ALM) character.
- .. _class_LineEdit_constant_MENU_INSERT_LRI:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_LRI** = ``22``
- Inserts left-to-right isolate (LRI) character.
- .. _class_LineEdit_constant_MENU_INSERT_RLI:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_RLI** = ``23``
- Inserts right-to-left isolate (RLI) character.
- .. _class_LineEdit_constant_MENU_INSERT_FSI:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_FSI** = ``24``
- Inserts first strong isolate (FSI) character.
- .. _class_LineEdit_constant_MENU_INSERT_PDI:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_PDI** = ``25``
- Inserts pop direction isolate (PDI) character.
- .. _class_LineEdit_constant_MENU_INSERT_ZWJ:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_ZWJ** = ``26``
- Inserts zero width joiner (ZWJ) character.
- .. _class_LineEdit_constant_MENU_INSERT_ZWNJ:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_ZWNJ** = ``27``
- Inserts zero width non-joiner (ZWNJ) character.
- .. _class_LineEdit_constant_MENU_INSERT_WJ:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_WJ** = ``28``
- Inserts word joiner (WJ) character.
- .. _class_LineEdit_constant_MENU_INSERT_SHY:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_INSERT_SHY** = ``29``
- Inserts soft hyphen (SHY) character.
- .. _class_LineEdit_constant_MENU_MAX:
- .. rst-class:: classref-enumeration-constant
- :ref:`MenuItems<enum_LineEdit_MenuItems>` **MENU_MAX** = ``30``
- Represents the size of the :ref:`MenuItems<enum_LineEdit_MenuItems>` enum.
- .. rst-class:: classref-item-separator
- ----
- .. _enum_LineEdit_VirtualKeyboardType:
- .. rst-class:: classref-enumeration
- enum **VirtualKeyboardType**:
- .. _class_LineEdit_constant_KEYBOARD_TYPE_DEFAULT:
- .. rst-class:: classref-enumeration-constant
- :ref:`VirtualKeyboardType<enum_LineEdit_VirtualKeyboardType>` **KEYBOARD_TYPE_DEFAULT** = ``0``
- Default text virtual keyboard.
- .. _class_LineEdit_constant_KEYBOARD_TYPE_MULTILINE:
- .. rst-class:: classref-enumeration-constant
- :ref:`VirtualKeyboardType<enum_LineEdit_VirtualKeyboardType>` **KEYBOARD_TYPE_MULTILINE** = ``1``
- Multiline virtual keyboard.
- .. _class_LineEdit_constant_KEYBOARD_TYPE_NUMBER:
- .. rst-class:: classref-enumeration-constant
- :ref:`VirtualKeyboardType<enum_LineEdit_VirtualKeyboardType>` **KEYBOARD_TYPE_NUMBER** = ``2``
- Virtual number keypad, useful for PIN entry.
- .. _class_LineEdit_constant_KEYBOARD_TYPE_NUMBER_DECIMAL:
- .. rst-class:: classref-enumeration-constant
- :ref:`VirtualKeyboardType<enum_LineEdit_VirtualKeyboardType>` **KEYBOARD_TYPE_NUMBER_DECIMAL** = ``3``
- Virtual number keypad, useful for entering fractional numbers.
- .. _class_LineEdit_constant_KEYBOARD_TYPE_PHONE:
- .. rst-class:: classref-enumeration-constant
- :ref:`VirtualKeyboardType<enum_LineEdit_VirtualKeyboardType>` **KEYBOARD_TYPE_PHONE** = ``4``
- Virtual phone number keypad.
- .. _class_LineEdit_constant_KEYBOARD_TYPE_EMAIL_ADDRESS:
- .. rst-class:: classref-enumeration-constant
- :ref:`VirtualKeyboardType<enum_LineEdit_VirtualKeyboardType>` **KEYBOARD_TYPE_EMAIL_ADDRESS** = ``5``
- Virtual keyboard with additional keys to assist with typing email addresses.
- .. _class_LineEdit_constant_KEYBOARD_TYPE_PASSWORD:
- .. rst-class:: classref-enumeration-constant
- :ref:`VirtualKeyboardType<enum_LineEdit_VirtualKeyboardType>` **KEYBOARD_TYPE_PASSWORD** = ``6``
- Virtual keyboard for entering a password. On most platforms, this should disable autocomplete and autocapitalization.
- \ **Note:** This is not supported on Web. Instead, this behaves identically to :ref:`KEYBOARD_TYPE_DEFAULT<class_LineEdit_constant_KEYBOARD_TYPE_DEFAULT>`.
- .. _class_LineEdit_constant_KEYBOARD_TYPE_URL:
- .. rst-class:: classref-enumeration-constant
- :ref:`VirtualKeyboardType<enum_LineEdit_VirtualKeyboardType>` **KEYBOARD_TYPE_URL** = ``7``
- Virtual keyboard with additional keys to assist with typing URLs.
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Property Descriptions
- ---------------------
- .. _class_LineEdit_property_alignment:
- .. rst-class:: classref-property
- :ref:`HorizontalAlignment<enum_@GlobalScope_HorizontalAlignment>` **alignment** = ``0``
- .. rst-class:: classref-property-setget
- - void **set_horizontal_alignment** **(** :ref:`HorizontalAlignment<enum_@GlobalScope_HorizontalAlignment>` value **)**
- - :ref:`HorizontalAlignment<enum_@GlobalScope_HorizontalAlignment>` **get_horizontal_alignment** **(** **)**
- Text alignment as defined in the :ref:`HorizontalAlignment<enum_@GlobalScope_HorizontalAlignment>` enum.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_caret_blink:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **caret_blink** = ``false``
- .. rst-class:: classref-property-setget
- - void **set_caret_blink_enabled** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_caret_blink_enabled** **(** **)**
- If ``true``, makes the caret blink.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_caret_blink_interval:
- .. rst-class:: classref-property
- :ref:`float<class_float>` **caret_blink_interval** = ``0.65``
- .. rst-class:: classref-property-setget
- - void **set_caret_blink_interval** **(** :ref:`float<class_float>` value **)**
- - :ref:`float<class_float>` **get_caret_blink_interval** **(** **)**
- The interval at which the caret blinks (in seconds).
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_caret_column:
- .. rst-class:: classref-property
- :ref:`int<class_int>` **caret_column** = ``0``
- .. rst-class:: classref-property-setget
- - void **set_caret_column** **(** :ref:`int<class_int>` value **)**
- - :ref:`int<class_int>` **get_caret_column** **(** **)**
- The caret's column position inside the **LineEdit**. When set, the text may scroll to accommodate it.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_caret_force_displayed:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **caret_force_displayed** = ``false``
- .. rst-class:: classref-property-setget
- - void **set_caret_force_displayed** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_caret_force_displayed** **(** **)**
- If ``true``, the **LineEdit** will always show the caret, even if focus is lost.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_caret_mid_grapheme:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **caret_mid_grapheme** = ``false``
- .. rst-class:: classref-property-setget
- - void **set_caret_mid_grapheme_enabled** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_caret_mid_grapheme_enabled** **(** **)**
- Allow moving caret, selecting and removing the individual composite character components.
- \ **Note:** :kbd:`Backspace` is always removing individual composite character components.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_clear_button_enabled:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **clear_button_enabled** = ``false``
- .. rst-class:: classref-property-setget
- - void **set_clear_button_enabled** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_clear_button_enabled** **(** **)**
- If ``true``, the **LineEdit** will show a clear button if :ref:`text<class_LineEdit_property_text>` is not empty, which can be used to clear the text quickly.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_context_menu_enabled:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **context_menu_enabled** = ``true``
- .. rst-class:: classref-property-setget
- - void **set_context_menu_enabled** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_context_menu_enabled** **(** **)**
- If ``true``, the context menu will appear when right-clicked.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_deselect_on_focus_loss_enabled:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **deselect_on_focus_loss_enabled** = ``true``
- .. rst-class:: classref-property-setget
- - void **set_deselect_on_focus_loss_enabled** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_deselect_on_focus_loss_enabled** **(** **)**
- If ``true``, the selected text will be deselected when focus is lost.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_drag_and_drop_selection_enabled:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **drag_and_drop_selection_enabled** = ``true``
- .. rst-class:: classref-property-setget
- - void **set_drag_and_drop_selection_enabled** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_drag_and_drop_selection_enabled** **(** **)**
- If ``true``, allow drag and drop of selected text.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_draw_control_chars:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **draw_control_chars** = ``false``
- .. rst-class:: classref-property-setget
- - void **set_draw_control_chars** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **get_draw_control_chars** **(** **)**
- If ``true``, control characters are displayed.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_editable:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **editable** = ``true``
- .. rst-class:: classref-property-setget
- - void **set_editable** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_editable** **(** **)**
- If ``false``, existing text cannot be modified and new text cannot be added.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_expand_to_text_length:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **expand_to_text_length** = ``false``
- .. rst-class:: classref-property-setget
- - void **set_expand_to_text_length_enabled** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_expand_to_text_length_enabled** **(** **)**
- If ``true``, the **LineEdit** width will increase to stay longer than the :ref:`text<class_LineEdit_property_text>`. It will **not** compress if the :ref:`text<class_LineEdit_property_text>` is shortened.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_flat:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **flat** = ``false``
- .. rst-class:: classref-property-setget
- - void **set_flat** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_flat** **(** **)**
- If ``true``, the **LineEdit** doesn't display decoration.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_language:
- .. rst-class:: classref-property
- :ref:`String<class_String>` **language** = ``""``
- .. rst-class:: classref-property-setget
- - void **set_language** **(** :ref:`String<class_String>` value **)**
- - :ref:`String<class_String>` **get_language** **(** **)**
- Language code used for line-breaking and text shaping algorithms. If left empty, current locale is used instead.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_max_length:
- .. rst-class:: classref-property
- :ref:`int<class_int>` **max_length** = ``0``
- .. rst-class:: classref-property-setget
- - void **set_max_length** **(** :ref:`int<class_int>` value **)**
- - :ref:`int<class_int>` **get_max_length** **(** **)**
- Maximum number of characters that can be entered inside the **LineEdit**. If ``0``, there is no limit.
- When a limit is defined, characters that would exceed :ref:`max_length<class_LineEdit_property_max_length>` are truncated. This happens both for existing :ref:`text<class_LineEdit_property_text>` contents when setting the max length, or for new text inserted in the **LineEdit**, including pasting. If any input text is truncated, the :ref:`text_change_rejected<class_LineEdit_signal_text_change_rejected>` signal is emitted with the truncated substring as parameter.
- \ **Example:**\
- .. tabs::
- .. code-tab:: gdscript
- text = "Hello world"
- max_length = 5
- # `text` becomes "Hello".
- max_length = 10
- text += " goodbye"
- # `text` becomes "Hello good".
- # `text_change_rejected` is emitted with "bye" as parameter.
- .. code-tab:: csharp
- Text = "Hello world";
- MaxLength = 5;
- // `Text` becomes "Hello".
- MaxLength = 10;
- Text += " goodbye";
- // `Text` becomes "Hello good".
- // `text_change_rejected` is emitted with "bye" as parameter.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_middle_mouse_paste_enabled:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **middle_mouse_paste_enabled** = ``true``
- .. rst-class:: classref-property-setget
- - void **set_middle_mouse_paste_enabled** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_middle_mouse_paste_enabled** **(** **)**
- If ``false``, using middle mouse button to paste clipboard will be disabled.
- \ **Note:** This method is only implemented on Linux.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_placeholder_text:
- .. rst-class:: classref-property
- :ref:`String<class_String>` **placeholder_text** = ``""``
- .. rst-class:: classref-property-setget
- - void **set_placeholder** **(** :ref:`String<class_String>` value **)**
- - :ref:`String<class_String>` **get_placeholder** **(** **)**
- Text shown when the **LineEdit** is empty. It is **not** the **LineEdit**'s default value (see :ref:`text<class_LineEdit_property_text>`).
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_right_icon:
- .. rst-class:: classref-property
- :ref:`Texture2D<class_Texture2D>` **right_icon**
- .. rst-class:: classref-property-setget
- - void **set_right_icon** **(** :ref:`Texture2D<class_Texture2D>` value **)**
- - :ref:`Texture2D<class_Texture2D>` **get_right_icon** **(** **)**
- Sets the icon that will appear in the right end of the **LineEdit** if there's no :ref:`text<class_LineEdit_property_text>`, or always, if :ref:`clear_button_enabled<class_LineEdit_property_clear_button_enabled>` is set to ``false``.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_secret:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **secret** = ``false``
- .. rst-class:: classref-property-setget
- - void **set_secret** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_secret** **(** **)**
- If ``true``, every character is replaced with the secret character (see :ref:`secret_character<class_LineEdit_property_secret_character>`).
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_secret_character:
- .. rst-class:: classref-property
- :ref:`String<class_String>` **secret_character** = ``"•"``
- .. rst-class:: classref-property-setget
- - void **set_secret_character** **(** :ref:`String<class_String>` value **)**
- - :ref:`String<class_String>` **get_secret_character** **(** **)**
- The character to use to mask secret input. Only a single character can be used as the secret character. If it is longer than one character, only the first one will be used. If it is empty, a space will be used instead.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_select_all_on_focus:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **select_all_on_focus** = ``false``
- .. rst-class:: classref-property-setget
- - void **set_select_all_on_focus** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_select_all_on_focus** **(** **)**
- If ``true``, the **LineEdit** will select the whole text when it gains focus.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_selecting_enabled:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **selecting_enabled** = ``true``
- .. rst-class:: classref-property-setget
- - void **set_selecting_enabled** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_selecting_enabled** **(** **)**
- If ``false``, it's impossible to select the text using mouse nor keyboard.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_shortcut_keys_enabled:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **shortcut_keys_enabled** = ``true``
- .. rst-class:: classref-property-setget
- - void **set_shortcut_keys_enabled** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_shortcut_keys_enabled** **(** **)**
- If ``false``, using shortcuts will be disabled.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_structured_text_bidi_override:
- .. rst-class:: classref-property
- :ref:`StructuredTextParser<enum_TextServer_StructuredTextParser>` **structured_text_bidi_override** = ``0``
- .. rst-class:: classref-property-setget
- - void **set_structured_text_bidi_override** **(** :ref:`StructuredTextParser<enum_TextServer_StructuredTextParser>` value **)**
- - :ref:`StructuredTextParser<enum_TextServer_StructuredTextParser>` **get_structured_text_bidi_override** **(** **)**
- Set BiDi algorithm override for the structured text.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_structured_text_bidi_override_options:
- .. rst-class:: classref-property
- :ref:`Array<class_Array>` **structured_text_bidi_override_options** = ``[]``
- .. rst-class:: classref-property-setget
- - void **set_structured_text_bidi_override_options** **(** :ref:`Array<class_Array>` value **)**
- - :ref:`Array<class_Array>` **get_structured_text_bidi_override_options** **(** **)**
- Set additional options for BiDi override.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_text:
- .. rst-class:: classref-property
- :ref:`String<class_String>` **text** = ``""``
- .. rst-class:: classref-property-setget
- - void **set_text** **(** :ref:`String<class_String>` value **)**
- - :ref:`String<class_String>` **get_text** **(** **)**
- String value of the **LineEdit**.
- \ **Note:** Changing text using this property won't emit the :ref:`text_changed<class_LineEdit_signal_text_changed>` signal.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_text_direction:
- .. rst-class:: classref-property
- :ref:`TextDirection<enum_Control_TextDirection>` **text_direction** = ``0``
- .. rst-class:: classref-property-setget
- - void **set_text_direction** **(** :ref:`TextDirection<enum_Control_TextDirection>` value **)**
- - :ref:`TextDirection<enum_Control_TextDirection>` **get_text_direction** **(** **)**
- Base text writing direction.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_virtual_keyboard_enabled:
- .. rst-class:: classref-property
- :ref:`bool<class_bool>` **virtual_keyboard_enabled** = ``true``
- .. rst-class:: classref-property-setget
- - void **set_virtual_keyboard_enabled** **(** :ref:`bool<class_bool>` value **)**
- - :ref:`bool<class_bool>` **is_virtual_keyboard_enabled** **(** **)**
- If ``true``, the native virtual keyboard is shown when focused on platforms that support it.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_property_virtual_keyboard_type:
- .. rst-class:: classref-property
- :ref:`VirtualKeyboardType<enum_LineEdit_VirtualKeyboardType>` **virtual_keyboard_type** = ``0``
- .. rst-class:: classref-property-setget
- - void **set_virtual_keyboard_type** **(** :ref:`VirtualKeyboardType<enum_LineEdit_VirtualKeyboardType>` value **)**
- - :ref:`VirtualKeyboardType<enum_LineEdit_VirtualKeyboardType>` **get_virtual_keyboard_type** **(** **)**
- Specifies the type of virtual keyboard to show.
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Method Descriptions
- -------------------
- .. _class_LineEdit_method_clear:
- .. rst-class:: classref-method
- void **clear** **(** **)**
- Erases the **LineEdit**'s :ref:`text<class_LineEdit_property_text>`.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_delete_char_at_caret:
- .. rst-class:: classref-method
- void **delete_char_at_caret** **(** **)**
- Deletes one character at the caret's current position (equivalent to pressing :kbd:`Delete`).
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_delete_text:
- .. rst-class:: classref-method
- void **delete_text** **(** :ref:`int<class_int>` from_column, :ref:`int<class_int>` to_column **)**
- Deletes a section of the :ref:`text<class_LineEdit_property_text>` going from position ``from_column`` to ``to_column``. Both parameters should be within the text's length.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_deselect:
- .. rst-class:: classref-method
- void **deselect** **(** **)**
- Clears the current selection.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_get_menu:
- .. rst-class:: classref-method
- :ref:`PopupMenu<class_PopupMenu>` **get_menu** **(** **)** |const|
- Returns the :ref:`PopupMenu<class_PopupMenu>` of this **LineEdit**. By default, this menu is displayed when right-clicking on the **LineEdit**.
- You can add custom menu items or remove standard ones. Make sure your IDs don't conflict with the standard ones (see :ref:`MenuItems<enum_LineEdit_MenuItems>`). For example:
- .. tabs::
- .. code-tab:: gdscript
- func _ready():
- var menu = get_menu()
- # Remove all items after "Redo".
- menu.item_count = menu.get_item_index(MENU_REDO) + 1
- # Add custom items.
- menu.add_separator()
- menu.add_item("Insert Date", MENU_MAX + 1)
- # Connect callback.
- menu.id_pressed.connect(_on_item_pressed)
-
- func _on_item_pressed(id):
- if id == MENU_MAX + 1:
- insert_text_at_caret(Time.get_date_string_from_system())
- .. code-tab:: csharp
- public override void _Ready()
- {
- var menu = GetMenu();
- // Remove all items after "Redo".
- menu.ItemCount = menu.GetItemIndex(LineEdit.MenuItems.Redo) + 1;
- // Add custom items.
- menu.AddSeparator();
- menu.AddItem("Insert Date", LineEdit.MenuItems.Max + 1);
- // Add event handler.
- menu.IdPressed += OnItemPressed;
- }
-
- public void OnItemPressed(int id)
- {
- if (id == LineEdit.MenuItems.Max + 1)
- {
- InsertTextAtCaret(Time.GetDateStringFromSystem());
- }
- }
- \ **Warning:** This is a required internal node, removing and freeing it may cause a crash. If you wish to hide it or any of its children, use their :ref:`Window.visible<class_Window_property_visible>` property.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_get_scroll_offset:
- .. rst-class:: classref-method
- :ref:`float<class_float>` **get_scroll_offset** **(** **)** |const|
- Returns the scroll offset due to :ref:`caret_column<class_LineEdit_property_caret_column>`, as a number of characters.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_get_selected_text:
- .. rst-class:: classref-method
- :ref:`String<class_String>` **get_selected_text** **(** **)**
- Returns the text inside the selection.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_get_selection_from_column:
- .. rst-class:: classref-method
- :ref:`int<class_int>` **get_selection_from_column** **(** **)** |const|
- Returns the selection begin column.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_get_selection_to_column:
- .. rst-class:: classref-method
- :ref:`int<class_int>` **get_selection_to_column** **(** **)** |const|
- Returns the selection end column.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_has_selection:
- .. rst-class:: classref-method
- :ref:`bool<class_bool>` **has_selection** **(** **)** |const|
- Returns ``true`` if the user has selected text.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_insert_text_at_caret:
- .. rst-class:: classref-method
- void **insert_text_at_caret** **(** :ref:`String<class_String>` text **)**
- Inserts ``text`` at the caret. If the resulting value is longer than :ref:`max_length<class_LineEdit_property_max_length>`, nothing happens.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_is_menu_visible:
- .. rst-class:: classref-method
- :ref:`bool<class_bool>` **is_menu_visible** **(** **)** |const|
- Returns whether the menu is visible. Use this instead of ``get_menu().visible`` to improve performance (so the creation of the menu is avoided).
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_menu_option:
- .. rst-class:: classref-method
- void **menu_option** **(** :ref:`int<class_int>` option **)**
- Executes a given action as defined in the :ref:`MenuItems<enum_LineEdit_MenuItems>` enum.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_select:
- .. rst-class:: classref-method
- void **select** **(** :ref:`int<class_int>` from=0, :ref:`int<class_int>` to=-1 **)**
- Selects characters inside **LineEdit** between ``from`` and ``to``. By default, ``from`` is at the beginning and ``to`` at the end.
- .. tabs::
- .. code-tab:: gdscript
- text = "Welcome"
- select() # Will select "Welcome".
- select(4) # Will select "ome".
- select(2, 5) # Will select "lco".
- .. code-tab:: csharp
- Text = "Welcome";
- Select(); // Will select "Welcome".
- Select(4); // Will select "ome".
- Select(2, 5); // Will select "lco".
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_method_select_all:
- .. rst-class:: classref-method
- void **select_all** **(** **)**
- Selects the whole :ref:`String<class_String>`.
- .. rst-class:: classref-section-separator
- ----
- .. rst-class:: classref-descriptions-group
- Theme Property Descriptions
- ---------------------------
- .. _class_LineEdit_theme_color_caret_color:
- .. rst-class:: classref-themeproperty
- :ref:`Color<class_Color>` **caret_color** = ``Color(0.95, 0.95, 0.95, 1)``
- Color of the **LineEdit**'s caret (text cursor). This can be set to a fully transparent color to hide the caret entirely.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_color_clear_button_color:
- .. rst-class:: classref-themeproperty
- :ref:`Color<class_Color>` **clear_button_color** = ``Color(0.875, 0.875, 0.875, 1)``
- Color used as default tint for the clear button.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_color_clear_button_color_pressed:
- .. rst-class:: classref-themeproperty
- :ref:`Color<class_Color>` **clear_button_color_pressed** = ``Color(1, 1, 1, 1)``
- Color used for the clear button when it's pressed.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_color_font_color:
- .. rst-class:: classref-themeproperty
- :ref:`Color<class_Color>` **font_color** = ``Color(0.875, 0.875, 0.875, 1)``
- Default font color.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_color_font_outline_color:
- .. rst-class:: classref-themeproperty
- :ref:`Color<class_Color>` **font_outline_color** = ``Color(1, 1, 1, 1)``
- The tint of text outline of the **LineEdit**.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_color_font_placeholder_color:
- .. rst-class:: classref-themeproperty
- :ref:`Color<class_Color>` **font_placeholder_color** = ``Color(0.875, 0.875, 0.875, 0.6)``
- Font color for :ref:`placeholder_text<class_LineEdit_property_placeholder_text>`.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_color_font_selected_color:
- .. rst-class:: classref-themeproperty
- :ref:`Color<class_Color>` **font_selected_color** = ``Color(1, 1, 1, 1)``
- Font color for selected text (inside the selection rectangle).
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_color_font_uneditable_color:
- .. rst-class:: classref-themeproperty
- :ref:`Color<class_Color>` **font_uneditable_color** = ``Color(0.875, 0.875, 0.875, 0.5)``
- Font color when editing is disabled.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_color_selection_color:
- .. rst-class:: classref-themeproperty
- :ref:`Color<class_Color>` **selection_color** = ``Color(0.5, 0.5, 0.5, 1)``
- Color of the selection rectangle.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_constant_caret_width:
- .. rst-class:: classref-themeproperty
- :ref:`int<class_int>` **caret_width** = ``1``
- The caret's width in pixels. Greater values can be used to improve accessibility by ensuring the caret is easily visible, or to ensure consistency with a large font size.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_constant_minimum_character_width:
- .. rst-class:: classref-themeproperty
- :ref:`int<class_int>` **minimum_character_width** = ``4``
- Minimum horizontal space for the text (not counting the clear button and content margins). This value is measured in count of 'M' characters (i.e. this number of 'M' characters can be displayed without scrolling).
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_constant_outline_size:
- .. rst-class:: classref-themeproperty
- :ref:`int<class_int>` **outline_size** = ``0``
- The size of the text outline.
- \ **Note:** If using a font with :ref:`FontFile.multichannel_signed_distance_field<class_FontFile_property_multichannel_signed_distance_field>` enabled, its :ref:`FontFile.msdf_pixel_range<class_FontFile_property_msdf_pixel_range>` must be set to at least *twice* the value of :ref:`outline_size<class_LineEdit_theme_constant_outline_size>` for outline rendering to look correct. Otherwise, the outline may appear to be cut off earlier than intended.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_font_font:
- .. rst-class:: classref-themeproperty
- :ref:`Font<class_Font>` **font**
- Font used for the text.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_font_size_font_size:
- .. rst-class:: classref-themeproperty
- :ref:`int<class_int>` **font_size**
- Font size of the **LineEdit**'s text.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_icon_clear:
- .. rst-class:: classref-themeproperty
- :ref:`Texture2D<class_Texture2D>` **clear**
- Texture for the clear button. See :ref:`clear_button_enabled<class_LineEdit_property_clear_button_enabled>`.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_style_focus:
- .. rst-class:: classref-themeproperty
- :ref:`StyleBox<class_StyleBox>` **focus**
- Background used when **LineEdit** has GUI focus. The :ref:`focus<class_LineEdit_theme_style_focus>` :ref:`StyleBox<class_StyleBox>` is displayed *over* the base :ref:`StyleBox<class_StyleBox>`, so a partially transparent :ref:`StyleBox<class_StyleBox>` should be used to ensure the base :ref:`StyleBox<class_StyleBox>` remains visible. A :ref:`StyleBox<class_StyleBox>` that represents an outline or an underline works well for this purpose. To disable the focus visual effect, assign a :ref:`StyleBoxEmpty<class_StyleBoxEmpty>` resource. Note that disabling the focus visual effect will harm keyboard/controller navigation usability, so this is not recommended for accessibility reasons.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_style_normal:
- .. rst-class:: classref-themeproperty
- :ref:`StyleBox<class_StyleBox>` **normal**
- Default background for the **LineEdit**.
- .. rst-class:: classref-item-separator
- ----
- .. _class_LineEdit_theme_style_read_only:
- .. rst-class:: classref-themeproperty
- :ref:`StyleBox<class_StyleBox>` **read_only**
- Background used when **LineEdit** is in read-only mode (:ref:`editable<class_LineEdit_property_editable>` is set to ``false``).
- .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
- .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
- .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`
- .. |constructor| replace:: :abbr:`constructor (This method is used to construct a type.)`
- .. |static| replace:: :abbr:`static (This method doesn't need an instance to be called, so it can be called directly using the class name.)`
- .. |operator| replace:: :abbr:`operator (This method describes a valid operator to use with this type as left-hand operand.)`
- .. |bitfield| replace:: :abbr:`BitField (This value is an integer composed as a bitmask of the following flags.)`
|