lv_ta: add 'max_length' and 'accepted_chars' features
This commit is contained in:
101
lv_objx/lv_ta.c
101
lv_objx/lv_ta.c
@@ -49,6 +49,7 @@ static void cursor_blink_anim(lv_obj_t * ta, uint8_t show);
|
|||||||
static void pwd_char_hider_anim(lv_obj_t * ta, int32_t x);
|
static void pwd_char_hider_anim(lv_obj_t * ta, int32_t x);
|
||||||
#endif
|
#endif
|
||||||
static void pwd_char_hider(lv_obj_t * ta);
|
static void pwd_char_hider(lv_obj_t * ta);
|
||||||
|
static bool char_is_accepted(lv_obj_t * ta, uint32_t c);
|
||||||
|
|
||||||
/**********************
|
/**********************
|
||||||
* STATIC VARIABLES
|
* STATIC VARIABLES
|
||||||
@@ -94,6 +95,8 @@ lv_obj_t * lv_ta_create(lv_obj_t * par, const lv_obj_t * copy)
|
|||||||
ext->cursor.state = 0;
|
ext->cursor.state = 0;
|
||||||
ext->pwd_mode = 0;
|
ext->pwd_mode = 0;
|
||||||
ext->pwd_tmp = NULL;
|
ext->pwd_tmp = NULL;
|
||||||
|
ext->accapted_chars = "abc123";
|
||||||
|
ext->max_length = 3;
|
||||||
ext->cursor.style = NULL;
|
ext->cursor.style = NULL;
|
||||||
ext->cursor.pos = 0;
|
ext->cursor.pos = 0;
|
||||||
ext->cursor.type = LV_CURSOR_LINE;
|
ext->cursor.type = LV_CURSOR_LINE;
|
||||||
@@ -101,7 +104,6 @@ lv_obj_t * lv_ta_create(lv_obj_t * par, const lv_obj_t * copy)
|
|||||||
ext->one_line = 0;
|
ext->one_line = 0;
|
||||||
ext->label = NULL;
|
ext->label = NULL;
|
||||||
|
|
||||||
|
|
||||||
lv_obj_set_signal_func(new_ta, lv_ta_signal);
|
lv_obj_set_signal_func(new_ta, lv_ta_signal);
|
||||||
lv_obj_set_signal_func(lv_page_get_scrl(new_ta), lv_ta_scrollable_signal);
|
lv_obj_set_signal_func(lv_page_get_scrl(new_ta), lv_ta_scrollable_signal);
|
||||||
lv_obj_set_design_func(new_ta, lv_ta_design);
|
lv_obj_set_design_func(new_ta, lv_ta_design);
|
||||||
@@ -187,6 +189,11 @@ void lv_ta_add_char(lv_obj_t * ta, char c)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(char_is_accepted(ta, c) == false) {
|
||||||
|
LV_LOG_INFO("Character is no accepted by the text area (too long text or not in the accepted list)");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if(ext->pwd_mode != 0) pwd_char_hider(ta); /*Make sure all the current text contains only '*'*/
|
if(ext->pwd_mode != 0) pwd_char_hider(ta); /*Make sure all the current text contains only '*'*/
|
||||||
char letter_buf[2];
|
char letter_buf[2];
|
||||||
letter_buf[0] = c;
|
letter_buf[0] = c;
|
||||||
@@ -235,11 +242,17 @@ void lv_ta_add_text(lv_obj_t * ta, const char * txt)
|
|||||||
lv_ta_ext_t * ext = lv_obj_get_ext_attr(ta);
|
lv_ta_ext_t * ext = lv_obj_get_ext_attr(ta);
|
||||||
|
|
||||||
if(ext->pwd_mode != 0) pwd_char_hider(ta); /*Make sure all the current text contains only '*'*/
|
if(ext->pwd_mode != 0) pwd_char_hider(ta); /*Make sure all the current text contains only '*'*/
|
||||||
|
|
||||||
|
/*If only one character is added check if it is accepted*/
|
||||||
|
if(lv_txt_get_encoded_length(txt) == 1) {
|
||||||
|
uint32_t c = lv_txt_encoded_next(txt, NULL);
|
||||||
|
if(char_is_accepted(ta, c) == false) {
|
||||||
|
LV_LOG_INFO("Character is no accepted by the text area (too long text or not in the accepted list)");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*Insert the text*/
|
/*Insert the text*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
lv_label_ins_text(ext->label, ext->cursor.pos, txt);
|
lv_label_ins_text(ext->label, ext->cursor.pos, txt);
|
||||||
|
|
||||||
if(ext->pwd_mode != 0) {
|
if(ext->pwd_mode != 0) {
|
||||||
@@ -518,6 +531,31 @@ void lv_ta_set_one_line(lv_obj_t * ta, bool en)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a list of characters. Only these characters will be accepted by the text area
|
||||||
|
* @param ta pointer to Text Area
|
||||||
|
* @param list list of characters. Only the pointer is saved. E.g. "+-.,0123456789"
|
||||||
|
*/
|
||||||
|
void lv_ta_set_accepted_chars(lv_obj_t * ta, const char * list)
|
||||||
|
{
|
||||||
|
lv_ta_ext_t * ext = lv_obj_get_ext_attr(ta);
|
||||||
|
|
||||||
|
ext->accapted_chars = list;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set max length of a Text Area.
|
||||||
|
* @param ta pointer to Text Area
|
||||||
|
* @param num the maximal number of characters can be added (`lv_ta_set_text` ignores it)
|
||||||
|
*/
|
||||||
|
void lv_ta_set_max_length(lv_obj_t * ta, uint16_t num)
|
||||||
|
{
|
||||||
|
lv_ta_ext_t * ext = lv_obj_get_ext_attr(ta);
|
||||||
|
|
||||||
|
ext->max_length = num;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set a style of a text area
|
* Set a style of a text area
|
||||||
* @param ta pointer to a text area object
|
* @param ta pointer to a text area object
|
||||||
@@ -547,7 +585,7 @@ void lv_ta_set_style(lv_obj_t * ta, lv_ta_style_t type, lv_style_t * style)
|
|||||||
*====================*/
|
*====================*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the text of a text area
|
* Get the text of a text area. In password mode it gives the real text (not '*'s).
|
||||||
* @param ta pointer to a text area object
|
* @param ta pointer to a text area object
|
||||||
* @return pointer to the text
|
* @return pointer to the text
|
||||||
*/
|
*/
|
||||||
@@ -622,6 +660,29 @@ bool lv_ta_get_one_line(const lv_obj_t * ta)
|
|||||||
return ext->one_line == 0 ? false : true;
|
return ext->one_line == 0 ? false : true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a list of accepted characters.
|
||||||
|
* @param ta pointer to Text Area
|
||||||
|
* @return list of accented characters.
|
||||||
|
*/
|
||||||
|
const char * lv_ta_get_accepted_chars(lv_obj_t * ta)
|
||||||
|
{
|
||||||
|
lv_ta_ext_t * ext = lv_obj_get_ext_attr(ta);
|
||||||
|
|
||||||
|
return ext->accapted_chars;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set max length of a Text Area.
|
||||||
|
* @param ta pointer to Text Area
|
||||||
|
* @return the maximal number of characters to be add
|
||||||
|
*/
|
||||||
|
uint16_t lv_ta_get_max_length(lv_obj_t * ta)
|
||||||
|
{
|
||||||
|
lv_ta_ext_t * ext = lv_obj_get_ext_attr(ta);
|
||||||
|
return ext->max_length;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get a style of a text area
|
* Get a style of a text area
|
||||||
* @param ta pointer to a text area object
|
* @param ta pointer to a text area object
|
||||||
@@ -1087,4 +1148,32 @@ static void pwd_char_hider(lv_obj_t * ta)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool char_is_accepted(lv_obj_t * ta, uint32_t c)
|
||||||
|
{
|
||||||
|
lv_ta_ext_t * ext = lv_obj_get_ext_attr(ta);
|
||||||
|
|
||||||
|
/*If no restriction accept it*/
|
||||||
|
if(ext->accapted_chars == NULL && ext->max_length == 0) return true;
|
||||||
|
|
||||||
|
/*Too many characters?*/
|
||||||
|
if(ext->max_length > 0 &&
|
||||||
|
lv_txt_get_encoded_length(lv_ta_get_text(ta)) >= ext->max_length) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*Accepted character?*/
|
||||||
|
if(ext->accapted_chars) {
|
||||||
|
uint32_t i = 0;
|
||||||
|
uint32_t a;
|
||||||
|
while(ext->accapted_chars[i] != '\0') {
|
||||||
|
a = lv_txt_encoded_next(ext->accapted_chars, &i);
|
||||||
|
if(a == c) return true; /*Accepted*/
|
||||||
|
}
|
||||||
|
|
||||||
|
return false; /*The character wasn't in the list*/
|
||||||
|
} else {
|
||||||
|
return true; /*If the accepted char list in not specified the accept the character*/
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -59,6 +59,8 @@ typedef struct
|
|||||||
/*New data for this type */
|
/*New data for this type */
|
||||||
lv_obj_t * label; /*Label of the text area*/
|
lv_obj_t * label; /*Label of the text area*/
|
||||||
char * pwd_tmp; /*Used to store the original text in password mode*/
|
char * pwd_tmp; /*Used to store the original text in password mode*/
|
||||||
|
const char * accapted_chars;/*Only these characters will be accepted. NULL: accept all*/
|
||||||
|
uint16_t max_length; /*The max. number of characters. 0: no limit*/
|
||||||
uint8_t pwd_mode :1; /*Replace characters with '*' */
|
uint8_t pwd_mode :1; /*Replace characters with '*' */
|
||||||
uint8_t one_line :1; /*One line mode (ignore line breaks)*/
|
uint8_t one_line :1; /*One line mode (ignore line breaks)*/
|
||||||
struct {
|
struct {
|
||||||
@@ -154,6 +156,19 @@ void lv_ta_set_pwd_mode(lv_obj_t * ta, bool pwd_en);
|
|||||||
*/
|
*/
|
||||||
void lv_ta_set_one_line(lv_obj_t * ta, bool en);
|
void lv_ta_set_one_line(lv_obj_t * ta, bool en);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set a list of characters. Only these characters will be accepted by the text area
|
||||||
|
* @param ta pointer to Text Area
|
||||||
|
* @param list list of characters. Only the pointer is saved. E.g. "+-.,0123456789"
|
||||||
|
*/
|
||||||
|
void lv_ta_set_accepted_chars(lv_obj_t * ta, const char * list);
|
||||||
|
/**
|
||||||
|
* Set max length of a Text Area.
|
||||||
|
* @param ta pointer to Text Area
|
||||||
|
* @param num the maximal number of characters can be added (`lv_ta_set_text` ignores it)
|
||||||
|
*/
|
||||||
|
void lv_ta_set_max_length(lv_obj_t * ta, uint16_t num);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the scroll bar mode of a text area
|
* Set the scroll bar mode of a text area
|
||||||
* @param ta pointer to a text area object
|
* @param ta pointer to a text area object
|
||||||
@@ -177,7 +192,7 @@ void lv_ta_set_style(lv_obj_t *ta, lv_ta_style_t type, lv_style_t *style);
|
|||||||
*====================*/
|
*====================*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the text of a text area
|
* Get the text of a text area. In password mode it gives the real text (not '*'s).
|
||||||
* @param ta pointer to a text area object
|
* @param ta pointer to a text area object
|
||||||
* @return pointer to the text
|
* @return pointer to the text
|
||||||
*/
|
*/
|
||||||
@@ -225,6 +240,20 @@ bool lv_ta_get_pwd_mode(const lv_obj_t * ta);
|
|||||||
*/
|
*/
|
||||||
bool lv_ta_get_one_line(const lv_obj_t * ta);
|
bool lv_ta_get_one_line(const lv_obj_t * ta);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a list of accepted characters.
|
||||||
|
* @param ta pointer to Text Area
|
||||||
|
* @return list of accented characters.
|
||||||
|
*/
|
||||||
|
const char * lv_ta_get_accepted_chars(lv_obj_t * ta);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set max length of a Text Area.
|
||||||
|
* @param ta pointer to Text Area
|
||||||
|
* @return the maximal number of characters to be add
|
||||||
|
*/
|
||||||
|
uint16_t lv_ta_get_max_length(lv_obj_t * ta);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the scroll bar mode of a text area
|
* Get the scroll bar mode of a text area
|
||||||
* @param ta pointer to a text area object
|
* @param ta pointer to a text area object
|
||||||
|
|||||||
Reference in New Issue
Block a user