1
0
mirror of https://github.com/lvgl/lvgl.git synced 2025-01-21 06:53:01 +08:00
lvgl/lv_objx/lv_label.h

296 lines
9.5 KiB
C
Raw Normal View History

2016-06-08 07:25:08 +02:00
/**
* @file lv_rect.h
2018-06-19 09:49:58 +02:00
*
2016-06-08 07:25:08 +02:00
*/
#ifndef LV_LABEL_H
#define LV_LABEL_H
2017-07-09 15:32:49 +02:00
#ifdef __cplusplus
extern "C" {
#endif
2016-06-08 07:25:08 +02:00
/*********************
* INCLUDES
*********************/
#ifdef LV_CONF_INCLUDE_SIMPLE
#include "lv_conf.h"
#else
2017-11-26 23:57:39 +01:00
#include "../../lv_conf.h"
#endif
2016-06-08 07:25:08 +02:00
#if USE_LV_LABEL != 0
2017-11-30 11:35:33 +01:00
#include "../lv_core/lv_obj.h"
2017-11-23 20:42:14 +01:00
#include "../lv_misc/lv_font.h"
2017-11-26 23:57:39 +01:00
#include "../lv_misc/lv_txt.h"
#include "../lv_misc/lv_symbol_def.h"
2016-06-08 07:25:08 +02:00
/*********************
* DEFINES
*********************/
2017-11-13 16:11:05 +01:00
#define LV_LABEL_DOT_NUM 3
2017-10-05 11:29:21 +02:00
#define LV_LABEL_POS_LAST 0xFFFF
2017-11-13 16:11:05 +01:00
2016-06-08 07:25:08 +02:00
/**********************
* TYPEDEFS
**********************/
/*Long mode behaviors. Used in 'lv_label_ext_t' */
2018-09-18 13:59:40 +02:00
enum
{
LV_LABEL_LONG_EXPAND, /*Expand the object size to the text size*/
2017-04-28 16:12:35 +02:00
LV_LABEL_LONG_BREAK, /*Keep the object width, break the too long lines and expand the object height*/
LV_LABEL_LONG_SCROLL, /*Expand the object size and scroll the text on the parent (move the label object)*/
2017-11-13 16:11:05 +01:00
LV_LABEL_LONG_DOT, /*Keep the size and write dots at the end if the text is too long*/
LV_LABEL_LONG_ROLL, /*Keep the size and roll the text infinitely*/
2018-09-25 16:21:31 +02:00
LV_LABEL_LONG_CROP, /*Keep the size and crop the text out of it*/
2018-09-18 13:59:40 +02:00
};
typedef uint8_t lv_label_long_mode_t;
/*Label align policy*/
2018-09-18 13:59:40 +02:00
enum {
LV_LABEL_ALIGN_LEFT,
LV_LABEL_ALIGN_CENTER,
LV_LABEL_ALIGN_RIGHT,
2018-09-18 13:59:40 +02:00
};
typedef uint8_t lv_label_align_t;
/*Data of label*/
typedef struct
{
/*Inherited from 'base_obj' so no inherited ext.*/ /*Ext. of ancestor*/
/*New data for this type */
char * text; /*Text of the label*/
lv_label_long_mode_t long_mode; /*Determinate what to do with the long texts*/
2017-11-26 14:39:22 +01:00
#if LV_TXT_UTF8 == 0
char dot_tmp[LV_LABEL_DOT_NUM + 1]; /*Store the character which are replaced by dots (Handled by the library)*/
2017-10-05 11:29:21 +02:00
#else
2017-11-13 16:11:05 +01:00
char dot_tmp[LV_LABEL_DOT_NUM * 4 + 1]; /*Store the character which are replaced by dots (Handled by the library)*/
2017-10-05 11:29:21 +02:00
#endif
#if USE_LV_MULTI_LANG > 0
const char ** multi_lang_texts; /*Store multiple languages statically (only the pointer is saved)*/
#endif
2017-04-21 09:15:39 +02:00
uint16_t dot_end; /*The text end position in dot mode (Handled by the library)*/
2017-11-13 16:11:05 +01:00
uint16_t anim_speed; /*Speed of scroll and roll animation in px/sec unit*/
lv_point_t offset; /*Text draw position offset*/
2017-04-11 10:50:57 +02:00
uint8_t static_txt :1; /*Flag to indicate the text is static*/
uint8_t align :2; /*Align type from 'lv_label_align_t'*/
2017-10-30 17:11:56 +01:00
uint8_t recolor :1; /*Enable in-line letter re-coloring*/
uint8_t expand :1; /*Ignore real width (used by the library with LV_LABEL_LONG_ROLL)*/
uint8_t body_draw :1; /*Draw background body*/
2018-06-19 09:49:58 +02:00
} lv_label_ext_t;
2016-06-08 07:25:08 +02:00
/**********************
* GLOBAL PROTOTYPES
**********************/
2017-11-13 16:11:05 +01:00
/**
* Create a label objects
* @param par pointer to an object, it will be the parent of the new label
* @param copy pointer to a button object, if not NULL then the new object will be copied from it
* @return pointer to the created button
*/
lv_obj_t * lv_label_create(lv_obj_t * par, const lv_obj_t * copy);
2017-11-13 16:11:05 +01:00
/*=====================
* Setter functions
*====================*/
/**
* Set a new text for a label. Memory will be allocated to store the text by the label.
* @param label pointer to a label object
* @param text '\0' terminated character string. NULL to refresh with the current text.
*/
2016-10-07 11:15:46 +02:00
void lv_label_set_text(lv_obj_t * label, const char * text);
/**
* Set a new text for a label from a character array. The array don't has to be '\0' terminated.
* Memory will be allocated to store the array by the label.
* @param label pointer to a label object
* @param array array of characters or NULL to refresh the label
* @param size the size of 'array' in bytes
*/
2017-11-13 16:11:05 +01:00
void lv_label_set_array_text(lv_obj_t * label, const char * array, uint16_t size);
/**
* Set a static text. It will not be saved by the label so the 'text' variable
* has to be 'alive' while the label exist.
* @param label pointer to a label object
* @param text pointer to a text. NULL to refresh with the current text.
*/
2017-11-13 16:11:05 +01:00
void lv_label_set_static_text(lv_obj_t * label, const char * text);
2017-04-21 09:15:39 +02:00
/**
* Set the text for the multiple languages
* @param label pointer to a label object
* @param texts '\0' terminated character strings like `const char * txts[] = {"dog", "hund"}`.
* The number of elements must be `USE_LV_MULTI_LANG`.
* Only the pointer is saved so the variable must be global, static, or dynamically allocated.
* NULL to disable multiple language for the label.
*/
void lv_label_set_text_multi(lv_obj_t * label, const char ** texts);
/**
* Set the behavior of the label with longer text then the object size
* @param label pointer to a label object
* @param long_mode the new mode from 'lv_label_long_mode' enum.
* In LV_LONG_BREAK/LONG/ROLL the size of the label should be set AFTER this function
*/
void lv_label_set_long_mode(lv_obj_t * label, lv_label_long_mode_t long_mode);
2017-11-13 16:11:05 +01:00
/**
* Set the align of the label (left or center)
* @param label pointer to a label object
* @param align 'LV_LABEL_ALIGN_LEFT' or 'LV_LABEL_ALIGN_LEFT'
*/
void lv_label_set_align(lv_obj_t *label, lv_label_align_t align);
/**
* Enable the recoloring by in-line commands
* @param label pointer to a label object
* @param en true: enable recoloring, false: disable
*/
void lv_label_set_recolor(lv_obj_t * label, bool en);
2017-06-13 14:17:33 +02:00
/**
2017-11-13 16:11:05 +01:00
* Set the label to draw (or not draw) background specified in its style's body
2017-06-13 14:17:33 +02:00
* @param label pointer to a label object
* @param en true: draw body; false: don't draw body
2017-06-13 14:17:33 +02:00
*/
void lv_label_set_body_draw(lv_obj_t *label, bool en);
2017-06-13 14:17:33 +02:00
2017-11-13 16:11:05 +01:00
/**
* Set the label's animation speed in LV_LABEL_LONG_ROLL and SCROLL modes
* @param label pointer to a label object
* @param anim_speed speed of animation in px/sec unit
*/
void lv_label_set_anim_speed(lv_obj_t *label, uint16_t anim_speed);
2017-10-30 17:11:56 +01:00
2017-11-13 16:11:05 +01:00
/**
* Set the style of an label
* @param label pointer to an label object
* @param style pointer to a style
*/
static inline void lv_label_set_style(lv_obj_t *label, lv_style_t *style)
{
lv_obj_set_style(label, style);
}
/*=====================
* Getter functions
*====================*/
/**
* Get the text of a label
* @param label pointer to a label object
* @return the text of the label
*/
char * lv_label_get_text(const lv_obj_t * label);
/**
* Get the array which stores the texts for multiple languages
* @param label pointer to a label object
* @return pointer to the array storing the texts. NULL if not specified.
*/
const char ** lv_label_get_text_multi(lv_obj_t * label);
/**
2017-11-13 16:11:05 +01:00
* Get the long mode of a label
* @param label pointer to a label object
2017-11-13 16:11:05 +01:00
* @return the long mode
*/
lv_label_long_mode_t lv_label_get_long_mode(const lv_obj_t * label);
/**
2017-11-13 16:11:05 +01:00
* Get the align attribute
* @param label pointer to a label object
2017-11-13 16:11:05 +01:00
* @return LV_LABEL_ALIGN_LEFT or LV_LABEL_ALIGN_CENTER
*/
lv_label_align_t lv_label_get_align(const lv_obj_t * label);
/**
* Get the recoloring attribute
* @param label pointer to a label object
* @return true: recoloring is enabled, false: disable
*/
bool lv_label_get_recolor(const lv_obj_t * label);
2017-10-30 17:11:56 +01:00
/**
* Get the body draw attribute
* @param label pointer to a label object
* @return true: draw body; false: don't draw body
*/
bool lv_label_get_body_draw(const lv_obj_t *label);
2017-10-30 17:11:56 +01:00
2017-06-13 14:17:33 +02:00
/**
2017-11-13 16:11:05 +01:00
* Get the label's animation speed in LV_LABEL_LONG_ROLL and SCROLL modes
2017-06-13 14:17:33 +02:00
* @param label pointer to a label object
2017-11-13 16:11:05 +01:00
* @return speed of animation in px/sec unit
2017-06-13 14:17:33 +02:00
*/
uint16_t lv_label_get_anim_speed(const lv_obj_t *label);
2017-06-13 14:17:33 +02:00
/**
* Get the relative x and y coordinates of a letter
* @param label pointer to a label object
2017-11-13 16:11:05 +01:00
* @param index index of the letter [0 ... text length]. Expressed in character index, not byte index (different in UTF-8)
* @param pos store the result here (E.g. index = 0 gives 0;0 coordinates)
*/
void lv_label_get_letter_pos(const lv_obj_t * label, uint16_t index, lv_point_t * pos);
/**
* Get the index of letter on a relative point of a label
* @param label pointer to label object
* @param pos pointer to point with coordinates on a the label
* @return the index of the letter on the 'pos_p' point (E.g. on 0;0 is the 0. letter)
2017-11-13 16:11:05 +01:00
* Expressed in character index and not byte index (different in UTF-8)
*/
uint16_t lv_label_get_letter_on(const lv_obj_t * label, lv_point_t * pos);
2016-06-08 07:25:08 +02:00
2017-11-13 16:11:05 +01:00
/**
* Get the style of an label object
* @param label pointer to an label object
* @return pointer to the label's style
2017-11-13 16:11:05 +01:00
*/
static inline lv_style_t* lv_label_get_style(const lv_obj_t *label)
2017-11-13 16:11:05 +01:00
{
return lv_obj_get_style(label);
}
/*=====================
* Other functions
*====================*/
/**
* Insert a text to the label. The label text can not be static.
* @param label pointer to a label object
* @param pos character index to insert. Expressed in character index and not byte index (Different in UTF-8)
* 0: before first char.
* LV_LABEL_POS_LAST: after last char.
* @param txt pointer to the text to insert
*/
void lv_label_ins_text(lv_obj_t * label, uint32_t pos, const char * txt);
/**
* Delete characters from a label. The label text can not be static.
* @param label pointer to a label object
* @param pos character index to insert. Expressed in character index and not byte index (Different in UTF-8)
* 0: before first char.
* @param cnt number of characters to cut
*/
void lv_label_cut_text(lv_obj_t * label, uint32_t pos, uint32_t cnt);
2016-06-08 07:25:08 +02:00
/**********************
* MACROS
**********************/
2017-07-09 15:32:49 +02:00
#endif /*USE_LV_LABEL*/
2016-06-08 07:25:08 +02:00
2017-07-09 15:32:49 +02:00
#ifdef __cplusplus
} /* extern "C" */
2016-06-08 07:25:08 +02:00
#endif
2017-07-09 15:32:49 +02:00
#endif /*LV_LABEL_H*/