2021-11-09 15:35:08 +01:00
|
|
|
#include "../../lv_examples.h"
|
2023-07-05 13:05:19 +02:00
|
|
|
//TODO
|
2023-07-10 05:27:32 +08:00
|
|
|
#if LV_USE_LABEL && LV_USE_CANVAS && LV_BUILD_EXAMPLES && LV_DRAW_SW_COMPLEX && 0
|
2021-11-09 15:35:08 +01:00
|
|
|
|
|
|
|
#define MASK_WIDTH 100
|
|
|
|
#define MASK_HEIGHT 45
|
|
|
|
|
|
|
|
static void add_mask_event_cb(lv_event_t * e)
|
|
|
|
{
|
|
|
|
static lv_draw_mask_map_param_t m;
|
|
|
|
static int16_t mask_id;
|
|
|
|
|
|
|
|
lv_event_code_t code = lv_event_get_code(e);
|
|
|
|
lv_obj_t * obj = lv_event_get_target(e);
|
|
|
|
lv_opa_t * mask_map = lv_event_get_user_data(e);
|
|
|
|
if(code == LV_EVENT_COVER_CHECK) {
|
|
|
|
lv_event_set_cover_res(e, LV_COVER_RES_MASKED);
|
|
|
|
}
|
|
|
|
else if(code == LV_EVENT_DRAW_MAIN_BEGIN) {
|
|
|
|
lv_draw_mask_map_init(&m, &obj->coords, mask_map);
|
|
|
|
mask_id = lv_draw_mask_add(&m, NULL);
|
|
|
|
|
|
|
|
}
|
|
|
|
else if(code == LV_EVENT_DRAW_MAIN_END) {
|
|
|
|
lv_draw_mask_free_param(&m);
|
|
|
|
lv_draw_mask_remove_id(mask_id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Draw label with gradient color
|
|
|
|
*/
|
|
|
|
void lv_example_label_4(void)
|
|
|
|
{
|
|
|
|
/* Create the mask of a text by drawing it to a canvas*/
|
2023-03-08 11:26:22 +01:00
|
|
|
static lv_color_t mask_map[MASK_WIDTH * MASK_HEIGHT];
|
2021-11-09 15:35:08 +01:00
|
|
|
|
|
|
|
/*Create a "8 bit alpha" canvas and clear it*/
|
|
|
|
lv_obj_t * canvas = lv_canvas_create(lv_scr_act());
|
2023-03-08 11:26:22 +01:00
|
|
|
lv_canvas_set_buffer(canvas, mask_map, MASK_WIDTH, MASK_HEIGHT, LV_COLOR_FORMAT_NATIVE);
|
2021-11-09 15:35:08 +01:00
|
|
|
lv_canvas_fill_bg(canvas, lv_color_black(), LV_OPA_TRANSP);
|
|
|
|
|
|
|
|
/*Draw a label to the canvas. The result "image" will be used as mask*/
|
|
|
|
lv_draw_label_dsc_t label_dsc;
|
|
|
|
lv_draw_label_dsc_init(&label_dsc);
|
|
|
|
label_dsc.color = lv_color_white();
|
|
|
|
label_dsc.align = LV_TEXT_ALIGN_CENTER;
|
2023-07-05 13:05:19 +02:00
|
|
|
label_dsc.text = "Text with gradient";
|
|
|
|
lv_canvas_draw_text(canvas, 5, 5, MASK_WIDTH, &label_dsc);
|
2021-11-09 15:35:08 +01:00
|
|
|
|
|
|
|
/*The mask is reads the canvas is not required anymore*/
|
|
|
|
lv_obj_del(canvas);
|
|
|
|
|
2023-03-08 11:26:22 +01:00
|
|
|
/*Convert the mask to A8*/
|
|
|
|
uint32_t i;
|
|
|
|
uint8_t * mask8 = (uint8_t *) mask_map;
|
|
|
|
lv_color_t * mask_c = mask_map;
|
|
|
|
for(i = 0; i < MASK_WIDTH * MASK_HEIGHT; i++) {
|
|
|
|
mask8[i] = lv_color_brightness(mask_c[i]);
|
|
|
|
}
|
|
|
|
|
2021-11-09 15:35:08 +01:00
|
|
|
/* Create an object from where the text will be masked out.
|
|
|
|
* Now it's a rectangle with a gradient but it could be an image too*/
|
|
|
|
lv_obj_t * grad = lv_obj_create(lv_scr_act());
|
|
|
|
lv_obj_set_size(grad, MASK_WIDTH, MASK_HEIGHT);
|
|
|
|
lv_obj_center(grad);
|
|
|
|
lv_obj_set_style_bg_color(grad, lv_color_hex(0xff0000), 0);
|
|
|
|
lv_obj_set_style_bg_grad_color(grad, lv_color_hex(0x0000ff), 0);
|
|
|
|
lv_obj_set_style_bg_grad_dir(grad, LV_GRAD_DIR_HOR, 0);
|
2023-02-20 20:50:58 +01:00
|
|
|
lv_obj_add_event(grad, add_mask_event_cb, LV_EVENT_ALL, mask_map);
|
2021-11-09 15:35:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|