2016-06-08 07:25:08 +02:00
|
|
|
/**
|
|
|
|
* @file lv_rect.h
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#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
|
|
|
|
*********************/
|
2016-06-10 15:00:56 +02:00
|
|
|
#include "lv_conf.h"
|
2016-06-08 07:25:08 +02:00
|
|
|
#if USE_LV_LABEL != 0
|
|
|
|
|
|
|
|
#include "../lv_obj/lv_obj.h"
|
2017-04-21 09:15:39 +02:00
|
|
|
#include "misc/gfx/font.h"
|
|
|
|
#include "misc/gfx/text.h"
|
2016-06-08 07:25:08 +02:00
|
|
|
|
|
|
|
/*********************
|
|
|
|
* DEFINES
|
|
|
|
*********************/
|
2016-10-16 21:43:28 +02:00
|
|
|
#define LV_LABEL_DOT_NUM 3
|
2016-06-08 07:25:08 +02:00
|
|
|
|
|
|
|
/**********************
|
|
|
|
* TYPEDEFS
|
|
|
|
**********************/
|
|
|
|
|
2017-01-14 23:54:16 +01:00
|
|
|
/*Long mode behaviors. Used in 'lv_label_ext_t' */
|
|
|
|
typedef 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_DOTS, /*Keep the object size, break the text and write dots in the last line*/
|
2017-01-14 23:54:16 +01:00
|
|
|
LV_LABEL_LONG_SCROLL, /*Expand the object size and scroll the text on the parent (move the label object)*/
|
2017-06-18 18:25:25 +02:00
|
|
|
LV_LABEL_LONG_ROLL, /*Keep the size and roll the text infinitely*/
|
2017-01-14 23:54:16 +01:00
|
|
|
}lv_label_long_mode_t;
|
|
|
|
|
|
|
|
/*Data of label*/
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
/*Inherited from 'base_obj' so no inherited ext.*/ /*Ext. of ancestor*/
|
|
|
|
/*New data for this type */
|
|
|
|
char * txt; /*Text of the label*/
|
|
|
|
lv_label_long_mode_t long_mode; /*Determinate what to do with the long texts*/
|
2017-05-10 16:11:20 +02:00
|
|
|
char dot_tmp[LV_LABEL_DOT_NUM + 1]; /*Store the character which are replaced by dots (Handled by the library)*/
|
2017-04-21 09:15:39 +02:00
|
|
|
uint16_t dot_end; /*The text end position in dot mode (Handled by the library)*/
|
2017-06-18 18:25:25 +02:00
|
|
|
point_t offset;
|
2017-04-11 10:50:57 +02:00
|
|
|
uint8_t static_txt :1; /*Flag to indicate the text is static*/
|
|
|
|
uint8_t recolor :1; /*Enable in-line letter re-coloring*/
|
2017-06-18 18:25:25 +02:00
|
|
|
uint8_t expand :1; /*Force expand size when solving line length (used by the library with LV_LABEL_LONG_ROLL)*/
|
2017-01-14 23:54:16 +01:00
|
|
|
}lv_label_ext_t;
|
|
|
|
|
2016-06-08 07:25:08 +02:00
|
|
|
/**********************
|
|
|
|
* GLOBAL PROTOTYPES
|
|
|
|
**********************/
|
2017-01-13 23:27:49 +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
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
lv_obj_t * lv_label_create(lv_obj_t * par, lv_obj_t * copy);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Signal function of the label
|
|
|
|
* @param label pointer to a label object
|
|
|
|
* @param sign a signal type from lv_signal_t enum
|
|
|
|
* @param param pointer to a signal specific variable
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
bool lv_label_signal(lv_obj_t * label, lv_signal_t sign, void * param);
|
2016-06-15 10:23:10 +02:00
|
|
|
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* 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);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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
|
|
|
|
*/
|
2016-12-30 21:42:59 +01:00
|
|
|
void lv_label_set_text_array(lv_obj_t * label, const char * array, uint16_t size);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
2016-12-30 21:42:59 +01:00
|
|
|
void lv_label_set_text_static(lv_obj_t * label, const char * text);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
2017-02-06 08:52:59 +01:00
|
|
|
/**
|
|
|
|
* Append a text to the label. The label current label text can not be static.
|
|
|
|
* @param label pointer to label object
|
|
|
|
* @param text pointe rto the new text
|
|
|
|
*/
|
|
|
|
void lv_label_append_text(lv_obj_t * label, const char * text);
|
2017-04-21 09:15:39 +02:00
|
|
|
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
2016-10-16 21:43:28 +02:00
|
|
|
void lv_label_set_long_mode(lv_obj_t * label, lv_label_long_mode_t long_mode);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
2017-02-01 11:39:48 +01:00
|
|
|
/**
|
|
|
|
* Enable the recoloring by in-line commands
|
|
|
|
* @param label pointer to a label object
|
|
|
|
* @param recolor true: enable recoloring, false: disable
|
|
|
|
*/
|
|
|
|
void lv_label_set_recolor(lv_obj_t * label, bool recolor);
|
|
|
|
|
2017-06-13 14:17:33 +02:00
|
|
|
/**
|
|
|
|
* Enable the password mode
|
|
|
|
* @param label pointer to a label object
|
|
|
|
* @param pwd true: enable password mode, false: disable
|
|
|
|
*/
|
|
|
|
void lv_label_set_pwd_mode(lv_obj_t * label, bool pwd);
|
|
|
|
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Get the text of a label
|
|
|
|
* @param label pointer to a label object
|
|
|
|
* @return the text of the label
|
|
|
|
*/
|
2017-07-07 16:22:24 +02:00
|
|
|
char * lv_label_get_text(lv_obj_t * label);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
2017-02-01 11:39:48 +01:00
|
|
|
* Get the long mode of a label
|
2017-01-13 23:27:49 +01:00
|
|
|
* @param label pointer to a label object
|
2017-02-01 11:39:48 +01:00
|
|
|
* @return the long mode
|
2017-01-13 23:27:49 +01:00
|
|
|
*/
|
2016-10-16 21:43:28 +02:00
|
|
|
lv_label_long_mode_t lv_label_get_long_mode(lv_obj_t * label);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
2017-02-01 11:39:48 +01:00
|
|
|
/**
|
|
|
|
* Get the recoloring attribute
|
|
|
|
* @param label pointer to a label object
|
|
|
|
* @return true: recoloring is enabled, false: disable
|
|
|
|
*/
|
|
|
|
bool lv_label_get_recolor(lv_obj_t * label);
|
|
|
|
|
2017-06-13 14:17:33 +02:00
|
|
|
/**
|
|
|
|
* Get the password mode
|
|
|
|
* @param label pointer to a label object
|
|
|
|
* @return true: password mode is enabled, false: disable
|
|
|
|
*/
|
|
|
|
bool lv_label_get_pwd_mode(lv_obj_t * label);
|
|
|
|
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Get the relative x and y coordinates of a letter
|
|
|
|
* @param label pointer to a label object
|
|
|
|
* @param index index of the letter (0 ... text length)
|
|
|
|
* @param pos store the result here (E.g. index = 0 gives 0;0 coordinates)
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
void lv_label_get_letter_pos(lv_obj_t * label, uint16_t index, point_t * pos);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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)
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
uint16_t lv_label_get_letter_on(lv_obj_t * label, point_t * pos);
|
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*/
|