2021-04-12 18:19:04 +02:00
```eval_rst
.. include:: /header.rst
:github_url: |github_link_base|/widgets/textarea.md
```
# Text area (lv_textarea)
## Overview
2021-05-13 15:39:26 +02:00
The Text Area is a [Base object ](widgets/obj ) with a [Label ](/widgets/core/label ) and a cursor on it.
2021-04-12 18:19:04 +02:00
Texts or characters can be added to it.
Long lines are wrapped and when the text becomes long enough the Text area can be scrolled.
2021-05-13 15:39:26 +02:00
One line mode and password modes are supported.
2021-04-12 18:19:04 +02:00
2021-05-13 15:39:26 +02:00
## Parts and Styles
2021-06-09 15:10:35 +02:00
- `LV_PART_MAIN` The background of the text area. Uses all the typical backgrond style properties and the text related style properties including `text_align` to align the text to the left, right or center.
2021-05-13 15:39:26 +02:00
- `LV_PART_SCROLLBAR` The scrollbar that is shown when the text is too long.
2021-06-09 15:10:35 +02:00
- `LV_PART_SELECTED` Detemines the style of the [selected text ](#text-selection ). Only `text_color` and `bg_color` style properties can be used.
2021-05-13 15:39:26 +02:00
- `LV_PART_CURSOR` Marks the position where the characters are inserted. The cursor's area is always the bounding box of the current character.
2021-06-09 15:10:35 +02:00
A block cursor can be created by adding a background color and background opacity to `LV_PART_CURSOR` 's style. The create line cursor leave the cursor transparent and set a left border.
The `anim_time` style property sets the cursor's blink time.
- `LV_PART_TEXTAREA_PLACEHOLDER` Unique to Text Area, allows styling the placeholder text.
2021-04-12 18:19:04 +02:00
## Usage
### Add text
2021-05-13 15:39:26 +02:00
You can insert text or characters to the current cursor's position with:
2021-04-12 18:19:04 +02:00
- `lv_textarea_add_char(textarea, 'c')`
- `lv_textarea_add_text(textarea, "insert this text")`
To add wide characters like `'á'` , `'ß'` or CJK characters use `lv_textarea_add_text(ta, "á")` .
`lv_textarea_set_text(ta, "New text")` changes the whole text.
### Placeholder
A placeholder text can be specified - which is displayed when the Text area is empty - with `lv_textarea_set_placeholder_text(ta, "Placeholder text")`
### Delete character
To delete a character from the left of the current cursor position use `lv_textarea_del_char(textarea)` .
To delete from the right use `lv_textarea_del_char_forward(textarea)`
### Move the cursor
2021-05-13 15:39:26 +02:00
The cursor position can be modified directly like `lv_textarea_set_cursor_pos(textarea, 10)` .
2021-04-12 18:19:04 +02:00
The `0` position means "before the first characters",
`LV_TA_CURSOR_LAST` means "after the last character"
You can step the cursor with
- `lv_textarea_cursor_right(textarea)`
- `lv_textarea_cursor_left(textarea)`
- `lv_textarea_cursor_up(textarea)`
- `lv_textarea_cursor_down(textarea)`
2021-05-13 15:39:26 +02:00
If `lv_textarea_set_cursor_click_pos(textarea, true)` is applied the cursor will jump to the position where the Text area was clicked.
2021-04-12 18:19:04 +02:00
### Hide the cursor
2021-06-09 15:10:35 +02:00
The cursor is always visible, however it can be a good idea to style it to be visible only in `LV_STATE_FOCUSED` state.
2021-04-12 18:19:04 +02:00
### One line mode
2021-06-09 15:10:35 +02:00
The Text area can be configured to be on a single line with `lv_textarea_set_one_line(textarea, true)` .
In this mode the height is set automatically to show only one line, line break characters are ignored, and word wrap is disabled.
2021-04-12 18:19:04 +02:00
### Password mode
2021-05-13 15:39:26 +02:00
The text area supports password mode which can be enabled with `lv_textarea_set_password_mode(textarea, true)` .
2021-04-12 18:19:04 +02:00
If the `•` ([Bullet, U+2022 ](http://www.fileformat.info/info/unicode/char/2022/index.htm )) character exists in the font, the entered characters are converted to it after some time or when a new character is entered.
If `•` not exists, `*` will be used.
2021-06-09 15:10:35 +02:00
In password mode `lv_textarea_get_text(textarea)` returns the actual text entered, not the bullet characters.
2021-04-12 18:19:04 +02:00
2021-05-13 15:39:26 +02:00
The visibility time can be adjusted with `LV_TEXTAREA_DEF_PWD_SHOW_TIME)` in `lv_conf.h` .
2021-04-12 18:19:04 +02:00
### Accepted characters
2021-05-13 15:39:26 +02:00
You can set a list of accepted characters with `lv_textarae_set_accepted_chars(textarea, "0123456789.+-")` .
2021-04-12 18:19:04 +02:00
Other characters will be ignored.
### Max text length
The maximum number of characters can be limited with `lv_textarea_set_max_length(textarea, max_char_num)`
### Very long texts
2021-06-09 15:10:35 +02:00
If there is a very long text in the Text area (e. g. > 20k characters), scrolling and drawing might be slow.
2021-05-13 15:39:26 +02:00
However, by enabling `LV_LABEL_LONG_TXT_HINT 1` in `lv_conf.h` the performance can be hugely improved.
2021-06-09 15:10:35 +02:00
This will save some additional information about the label to speed up its drawing.
2021-04-12 18:19:04 +02:00
Using `LV_LABEL_LONG_TXT_HINT` the scrolling and drawing will as fast as with "normal" short texts.
### Select text
2021-06-09 15:10:35 +02:00
Any part of the text can be selected if enabled with `lv_textarea_set_text_selection(textarea, true)` .
This works much like when you select text on your PC with your mouse.
2021-04-12 18:19:04 +02:00
## Events
2021-06-09 15:10:35 +02:00
- `LV_EVENT_INSERT` Sent right before a character or text is inserted.
The event paramter is the text about to be inserted. `lv_textarea_set_insert_replace(textarea, "New text")` replaces the text to insert.
The new text cannot be in a local variable which is destroyed when the event callback exists. `""` means do not insert anything.
2021-05-13 15:39:26 +02:00
- `LV_EVENT_VALUE_CHANGED` Sent when the content of the text area has been changed.
- `LV_EVENT_APPLY` Sent when `LV_KEY_ENTER` is pressed (or(sent) to a one line text area.
Learn more about [Events ](/overview/event ).
2021-04-12 18:19:04 +02:00
## Keys
2021-05-13 15:39:26 +02:00
- `LV_KEY_UP/DOWN/LEFT/RIGHT` Move the cursor
- `Any character` Add the character to the current cursor position
2021-04-12 18:19:04 +02:00
Learn more about [Keys ](/overview/indev ).
## Example
```eval_rst
2021-05-03 17:32:57 +02:00
.. include:: ../../../examples/widgets/textarea/index.rst
2021-04-12 18:19:04 +02:00
```
## API
```eval_rst
.. doxygenfile:: lv_textarea.h
:project: lvgl
```