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

297 lines
7.2 KiB
C
Raw Normal View History

/**
* @file lv_style.h
*
*/
#ifndef LV_STYLE_H
#define LV_STYLE_H
2017-07-09 15:32:49 +02:00
#ifdef __cplusplus
extern "C" {
#endif
/*********************
* INCLUDES
*********************/
#include <stdbool.h>
#include "../lv_font/lv_font.h"
2017-11-23 20:42:14 +01:00
#include "../lv_misc/lv_color.h"
#include "../lv_misc/lv_area.h"
#include "../lv_misc/lv_anim.h"
/*********************
* DEFINES
*********************/
2019-04-04 07:15:40 +02:00
#define LV_RADIUS_CIRCLE (LV_COORD_MAX) /*A very big radius to always draw as circle*/
/**********************
* TYPEDEFS
**********************/
2017-04-21 09:15:39 +02:00
/*Border types (Use 'OR'ed values)*/
2019-04-04 07:15:40 +02:00
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)*/
2018-09-18 13:59:40 +02:00
};
typedef uint8_t lv_border_part_t;
2017-04-24 12:08:24 +02:00
/*Shadow types*/
2019-04-04 07:15:40 +02:00
enum {
2017-10-19 12:46:49 +02:00
LV_SHADOW_BOTTOM = 0,
LV_SHADOW_FULL,
2018-09-18 13:59:40 +02:00
};
typedef uint8_t lv_shadow_type_t;
2017-04-24 12:08:24 +02:00
typedef struct
{
2019-04-04 07:15:40 +02:00
uint8_t glass : 1; /*1: Do not inherit this style*/
2017-10-19 12:46:49 +02:00
2019-04-04 07:15:40 +02:00
struct
{
2017-11-23 21:28:36 +01:00
lv_color_t main_color;
2019-04-04 07:15:40 +02:00
lv_color_t grad_color; /*`grad_color` will be removed in v6.0, use `aux_color` instead*/
2017-11-23 21:28:36 +01:00
lv_coord_t radius;
lv_opa_t opa;
2019-04-04 07:15:40 +02:00
struct
{
2017-11-23 21:28:36 +01:00
lv_color_t color;
lv_coord_t width;
lv_border_part_t part;
2017-11-23 21:28:36 +01:00
lv_opa_t opa;
2018-06-19 09:49:58 +02:00
} border;
2019-04-04 07:15:40 +02:00
struct
{
2017-11-23 21:28:36 +01:00
lv_color_t color;
lv_coord_t width;
2018-09-18 13:59:40 +02:00
lv_shadow_type_t type;
2018-06-19 09:49:58 +02:00
} shadow;
2019-04-04 07:15:40 +02:00
struct
{
lv_coord_t top;
lv_coord_t bottom;
lv_coord_t left;
lv_coord_t right;
2017-11-23 21:28:36 +01:00
lv_coord_t inner;
2018-06-19 09:49:58 +02:00
} padding;
} body;
2017-10-18 16:07:19 +02:00
2019-04-04 07:15:40 +02:00
struct
{
2017-11-23 21:28:36 +01:00
lv_color_t color;
lv_color_t sel_color;
2017-11-23 21:28:36 +01:00
const lv_font_t * font;
lv_coord_t letter_space;
lv_coord_t line_space;
lv_opa_t opa;
2018-06-19 09:49:58 +02:00
} text;
2017-10-18 16:07:19 +02:00
2019-04-04 07:15:40 +02:00
struct
{
2017-11-23 21:28:36 +01:00
lv_color_t color;
lv_opa_t intense;
lv_opa_t opa;
2018-06-19 09:49:58 +02:00
} image;
2017-10-18 16:07:19 +02:00
2019-04-04 07:15:40 +02:00
struct
{
2017-11-23 21:28:36 +01:00
lv_color_t color;
lv_coord_t width;
lv_opa_t opa;
2019-04-04 07:15:40 +02:00
uint8_t rounded : 1; /*1: rounded line endings*/
2018-06-19 09:49:58 +02:00
} line;
} lv_style_t;
#if LV_USE_ANIMATION
2019-04-04 07:15:40 +02:00
typedef struct
{
lv_style_t style_start; /*Save not only pointers because can be same as 'style_anim' then it
will be modified too*/
lv_style_t style_end;
lv_style_t * style_anim;
lv_anim_ready_cb_t ready_cb;
} lv_style_anim_dsc_t;
2019-04-22 08:45:07 +02:00
#endif
/**********************
* GLOBAL PROTOTYPES
**********************/
2019-04-22 08:45:07 +02:00
/**
* Init the basic styles
2017-07-28 13:57:56 +02:00
*/
void lv_style_init(void);
2019-05-15 06:15:12 +02:00
/**
* 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);
2019-05-15 06:15:12 +02:00
/**
* 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
*/
2019-06-06 06:05:40 +02:00
void lv_style_mix(const lv_style_t * start, const lv_style_t * end, lv_style_t * res, uint16_t ratio);
2019-05-15 06:15:12 +02:00
#if LV_USE_ANIMATION
2019-05-15 06:15:12 +02:00
/**
* Initialize an animation variable.
* E.g.:
* lv_anim_t a;
* lv_style_anim__init(&a);
* lv_style_anim_set_...(&a);
* lv_style_anim_create(&a);
* @param a pointer to an `lv_anim_t` variable to initialize
*/
void lv_style_anim_init(lv_anim_t * a);
2019-05-15 06:15:12 +02:00
/**
*
* @param a pointer to an initialized `lv_anim_t` variable
* @param to_anim pointer to the style to animate
* @param start pointer to a style to animate from (start value)
* @param end pointer to a style to animate to (end value)
*/
void lv_style_anim_set_styles(lv_anim_t * a, lv_style_t * to_anim, const lv_style_t * start, const lv_style_t * end);
2019-05-15 06:15:12 +02:00
/**
* Set the duration and delay of an animation
* @param a pointer to an initialized `lv_anim_t` variable
* @param duration duration of the animation in milliseconds
* @param delay delay before the animation in milliseconds
*/
static inline void lv_style_anim_set_time(lv_anim_t * a, uint16_t duration, uint16_t delay)
2019-05-15 06:15:12 +02:00
{
lv_anim_set_time(a, duration, delay);
2019-05-15 06:15:12 +02:00
}
/**
* Set a function call when the animation is ready
* @param a pointer to an initialized `lv_anim_t` variable
* @param ready_cb a function call when the animation is ready
*/
static inline void lv_style_anim_set_ready_cb(lv_anim_t * a, lv_anim_ready_cb_t ready_cb)
2019-05-15 06:15:12 +02:00
{
lv_style_anim_dsc_t * dsc = a->var;
2019-06-06 06:05:40 +02:00
dsc->ready_cb = ready_cb;
2019-05-15 06:15:12 +02:00
}
/**
* Make the animation to play back to when the forward direction is ready
* @param a pointer to an initialized `lv_anim_t` variable
* @param wait_time time in milliseconds to wait before starting the back direction
*/
static inline void lv_style_anim_set_playback(lv_anim_t * a, uint16_t wait_time)
2019-05-15 06:15:12 +02:00
{
lv_anim_set_playback(a, wait_time);
2019-05-15 06:15:12 +02:00
}
/**
* Disable playback. (Disabled after `lv_anim_init()`)
* @param a pointer to an initialized `lv_anim_t` variable
*/
static inline void lv_style_anim_clear_playback(lv_anim_t * a)
2019-05-15 06:15:12 +02:00
{
lv_anim_clear_playback(a);
2019-05-15 06:15:12 +02:00
}
/**
* Make the animation to start again when ready.
* @param a pointer to an initialized `lv_anim_t` variable
* @param wait_time time in milliseconds to wait before starting the animation again
*/
static inline void lv_style_anim_set_repeat(lv_anim_t * a, uint16_t wait_time)
2019-05-15 06:15:12 +02:00
{
lv_anim_set_repeat(a, wait_time);
2019-05-15 06:15:12 +02:00
}
/**
* Disable repeat. (Disabled after `lv_anim_init()`)
* @param a pointer to an initialized `lv_anim_t` variable
*/
static inline void lv_style_anim_clear_repeat(lv_anim_t * a)
2019-05-15 06:15:12 +02:00
{
lv_anim_clear_repeat(a);
2019-05-15 06:15:12 +02:00
}
/**
* Set a user specific data for the animation
* @param a pointer to an initialized `lv_anim_t` variable
* @param user_data the user data
*/
static inline void lv_style_anim_set_user_data(lv_anim_t * a, lv_anim_user_data_t user_data)
2019-05-15 06:15:12 +02:00
{
lv_anim_set_user_data(a, user_data);
2019-05-15 06:15:12 +02:00
}
/**
* Get the user data
* @param a pointer to an initialized `lv_anim_t` variable
* @return the user data
*/
static inline lv_anim_user_data_t lv_style_anim_get_user_data(lv_anim_t * a)
{
return lv_anim_get_user_data(a);
}
2017-07-28 13:57:56 +02:00
/**
* Get pointer to the user data
* @param a pointer to an initialized `lv_anim_t` variable
* @return pointer to the user data
2017-07-28 13:57:56 +02:00
*/
static inline lv_anim_user_data_t * lv_style_anim_get_user_data_ptr(lv_anim_t * a)
{
return lv_anim_get_user_data_ptr(a);
}
2018-08-26 13:49:23 +02:00
/**
* Create an animation
* @param a an initialized 'anim_t' variable. Not required after call.
2018-08-26 13:49:23 +02:00
*/
static inline void lv_style_anim_create(lv_anim_t * a)
{
lv_anim_create(a);
}
2017-11-27 17:48:54 +01:00
#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;
2017-11-20 14:26:18 +01:00
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;
2019-02-20 22:36:56 +01:00
extern lv_style_t lv_style_btn_tgl_pr;
2017-11-20 14:26:18 +01:00
extern lv_style_t lv_style_btn_ina;
/**********************
* MACROS
**********************/
2017-07-09 15:32:49 +02:00
#ifdef __cplusplus
} /* extern "C" */
#endif
2017-07-09 15:32:49 +02:00
2019-04-04 07:15:40 +02:00
#endif /*LV_STYLE_H*/