2018-06-07 15:32:19 +02:00
|
|
|
/**
|
|
|
|
* @file lv_draw_label.h
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef LV_DRAW_LABEL_H
|
|
|
|
#define LV_DRAW_LABEL_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
* INCLUDES
|
|
|
|
*********************/
|
|
|
|
#include "lv_draw.h"
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
* DEFINES
|
|
|
|
*********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* TYPEDEFS
|
|
|
|
**********************/
|
2019-06-14 16:04:15 +02:00
|
|
|
|
|
|
|
/* Store some info to speed up drawing of very large texts
|
|
|
|
* It takes a lot of time to get the first visible character because
|
|
|
|
* all the previous characters needs to be checked to calculate the positions.
|
|
|
|
* This structure stores an earlier (e.g. at -1000 px) coordinate and the index of that line.
|
|
|
|
* Therefore the calculations can start from here.*/
|
|
|
|
typedef struct {
|
|
|
|
/*Index of the line at `y` coordinate*/
|
2019-06-14 14:57:59 +02:00
|
|
|
int32_t line_start;
|
2019-06-14 16:04:15 +02:00
|
|
|
|
|
|
|
/*Give the `y` coordinate of the first letter at `line start` index. Relative to the label's coordinates*/
|
2019-06-14 14:57:59 +02:00
|
|
|
int32_t y;
|
2019-06-14 16:04:15 +02:00
|
|
|
|
|
|
|
/*The 'y1' coordinate of the label when the hint was saved.
|
|
|
|
* Used to invalidate the hint if the label has moved too much. */
|
2019-06-14 14:57:59 +02:00
|
|
|
int32_t coord_y;
|
|
|
|
}lv_draw_label_hint_t;
|
2018-06-07 15:32:19 +02:00
|
|
|
|
|
|
|
/**********************
|
|
|
|
* GLOBAL PROTOTYPES
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Write a text
|
|
|
|
* @param coords coordinates of the label
|
|
|
|
* @param mask the label will be drawn only in this area
|
|
|
|
* @param style pointer to a style
|
2018-06-14 13:08:19 +02:00
|
|
|
* @param opa_scale scale down all opacities by the factor
|
2018-06-07 15:32:19 +02:00
|
|
|
* @param txt 0 terminated text to write
|
|
|
|
* @param flag settings for the text from 'txt_flag_t' enum
|
|
|
|
* @param offset text offset in x and y direction (NULL if unused)
|
2019-04-18 06:45:45 +02:00
|
|
|
* @param sel_start start index of selected area (`LV_LABEL_TXT_SEL_OFF` if none)
|
|
|
|
* @param sel_end end index of selected area (`LV_LABEL_TXT_SEL_OFF` if none)
|
2018-06-07 15:32:19 +02:00
|
|
|
*/
|
2019-06-06 06:05:40 +02:00
|
|
|
void lv_draw_label(const lv_area_t * coords, const lv_area_t * mask, const lv_style_t * style, lv_opa_t opa_scale,
|
2019-06-14 14:57:59 +02:00
|
|
|
const char * txt, lv_txt_flag_t flag, lv_point_t * offset, uint16_t sel_start, uint16_t sel_end, lv_draw_label_hint_t * hint);
|
2018-06-07 15:32:19 +02:00
|
|
|
|
|
|
|
/**********************
|
|
|
|
* MACROS
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
} /* extern "C" */
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /*LV_DRAW_LABEL_H*/
|