mirror of
https://github.com/lvgl/lvgl.git
synced 2025-01-21 06:53:01 +08:00
198 lines
4.8 KiB
C
198 lines
4.8 KiB
C
/**
|
|
* @file lv_style.h
|
|
*
|
|
*/
|
|
|
|
#ifndef LV_STYLE_H
|
|
#define LV_STYLE_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/*********************
|
|
* INCLUDES
|
|
*********************/
|
|
#include <stdbool.h>
|
|
#include "../lv_misc/lv_color.h"
|
|
#include "../lv_misc/lv_area.h"
|
|
#include "../lv_misc/lv_font.h"
|
|
#include "../lv_misc/lv_anim.h"
|
|
|
|
/*********************
|
|
* DEFINES
|
|
*********************/
|
|
#define LV_RADIUS_CIRCLE (LV_COORD_MAX) /*A very big radius to always draw as circle*/
|
|
|
|
/**********************
|
|
* TYPEDEFS
|
|
**********************/
|
|
|
|
/*Border types (Use 'OR'ed values)*/
|
|
enum
|
|
{
|
|
LV_BORDER_NONE = 0x00,
|
|
LV_BORDER_BOTTOM = 0x01,
|
|
LV_BORDER_TOP = 0x02,
|
|
LV_BORDER_LEFT = 0x04,
|
|
LV_BORDER_RIGHT = 0x08,
|
|
LV_BORDER_FULL = 0x0F,
|
|
LV_BORDER_INTERNAL = 0x10, /*FOR matrix-like objects (e.g. Button matrix)*/
|
|
};
|
|
typedef uint8_t lv_border_part_t;
|
|
|
|
/*Shadow types*/
|
|
enum
|
|
{
|
|
LV_SHADOW_BOTTOM = 0,
|
|
LV_SHADOW_FULL,
|
|
};
|
|
typedef uint8_t lv_shadow_type_t;
|
|
|
|
typedef struct
|
|
{
|
|
uint8_t glass :1; /*1: Do not inherit this style*/
|
|
|
|
struct {
|
|
lv_color_t main_color;
|
|
lv_color_t grad_color; /*`grad_color` will be removed in v6.0, use `aux_color` instead*/
|
|
lv_coord_t radius;
|
|
lv_opa_t opa;
|
|
|
|
struct {
|
|
lv_color_t color;
|
|
lv_coord_t width;
|
|
lv_border_part_t part;
|
|
lv_opa_t opa;
|
|
} border;
|
|
|
|
struct {
|
|
lv_color_t color;
|
|
lv_coord_t width;
|
|
lv_shadow_type_t type;
|
|
} shadow;
|
|
|
|
struct {
|
|
lv_coord_t ver;
|
|
lv_coord_t hor;
|
|
lv_coord_t inner;
|
|
} padding;
|
|
} body;
|
|
|
|
|
|
struct {
|
|
lv_color_t color;
|
|
const lv_font_t * font;
|
|
lv_coord_t letter_space;
|
|
lv_coord_t line_space;
|
|
lv_opa_t opa;
|
|
} text;
|
|
|
|
struct {
|
|
lv_color_t color;
|
|
lv_opa_t intense;
|
|
lv_opa_t opa;
|
|
} image;
|
|
|
|
struct {
|
|
lv_color_t color;
|
|
lv_coord_t width;
|
|
lv_opa_t opa;
|
|
uint8_t rounded :1; /*1: rounded line endings*/
|
|
} line;
|
|
} lv_style_t;
|
|
|
|
#if USE_LV_ANIMATION
|
|
typedef struct {
|
|
const lv_style_t * style_start; /*Pointer to the starting style*/
|
|
const lv_style_t * style_end; /*Pointer to the destination style*/
|
|
lv_style_t * style_anim; /*Pointer to a style to animate*/
|
|
lv_anim_cb_t end_cb; /*Call it when the animation is ready (NULL if unused)*/
|
|
int16_t time; /*Animation time in ms*/
|
|
int16_t act_time; /*Current time in animation. Set to negative to make delay.*/
|
|
uint16_t playback_pause; /*Wait before play back*/
|
|
uint16_t repeat_pause; /*Wait before repeat*/
|
|
uint8_t playback :1; /*When the animation is ready play it back*/
|
|
uint8_t repeat :1; /*Repeat the animation infinitely*/
|
|
} lv_style_anim_t;
|
|
|
|
/* Example initialization
|
|
lv_style_anim_t a;
|
|
a.style_anim = &style_to_anim;
|
|
a.style_start = &style_1;
|
|
a.style_end = &style_2;
|
|
a.act_time = 0;
|
|
a.time = 1000;
|
|
a.playback = 0;
|
|
a.playback_pause = 0;
|
|
a.repeat = 0;
|
|
a.repeat_pause = 0;
|
|
a.end_cb = NULL;
|
|
lv_style_anim_create(&a);
|
|
*/
|
|
#endif
|
|
|
|
/**********************
|
|
* GLOBAL PROTOTYPES
|
|
**********************/
|
|
|
|
/**
|
|
* Init the basic styles
|
|
*/
|
|
void lv_style_init (void);
|
|
|
|
/**
|
|
* Copy a style to an other
|
|
* @param dest pointer to the destination style
|
|
* @param src pointer to the source style
|
|
*/
|
|
void lv_style_copy(lv_style_t * dest, const lv_style_t * src);
|
|
|
|
|
|
/**
|
|
* Mix two styles according to a given ratio
|
|
* @param start start style
|
|
* @param end end style
|
|
* @param res store the result style here
|
|
* @param ratio the ratio of mix [0..256]; 0: `start` style; 256: `end` style
|
|
*/
|
|
void lv_style_mix(const lv_style_t * start, const lv_style_t * end, lv_style_t * res, uint16_t ratio);
|
|
|
|
#if USE_LV_ANIMATION
|
|
|
|
/**
|
|
* Create an animation from a pre-configured 'lv_style_anim_t' variable
|
|
* @param anim pointer to a pre-configured 'lv_style_anim_t' variable (will be copied)
|
|
* @return pointer to a descriptor. Really this variable will be animated. (Can be used in `lv_anim_del(dsc, NULL)`)
|
|
*/
|
|
void * lv_style_anim_create(lv_style_anim_t * anim);
|
|
#endif
|
|
|
|
/*************************
|
|
* GLOBAL VARIABLES
|
|
*************************/
|
|
extern lv_style_t lv_style_scr;
|
|
extern lv_style_t lv_style_transp;
|
|
extern lv_style_t lv_style_transp_fit;
|
|
extern lv_style_t lv_style_transp_tight;
|
|
extern lv_style_t lv_style_plain;
|
|
extern lv_style_t lv_style_plain_color;
|
|
extern lv_style_t lv_style_pretty;
|
|
extern lv_style_t lv_style_pretty_color;
|
|
extern lv_style_t lv_style_btn_rel;
|
|
extern lv_style_t lv_style_btn_pr;
|
|
extern lv_style_t lv_style_btn_tgl_rel;
|
|
extern lv_style_t lv_style_btn_tgl_pr;
|
|
extern lv_style_t lv_style_btn_ina;
|
|
|
|
/**********************
|
|
* MACROS
|
|
**********************/
|
|
|
|
|
|
#ifdef __cplusplus
|
|
} /* extern "C" */
|
|
#endif
|
|
|
|
#endif /*LV_STYLE_H*/
|