2021-04-08 13:07:48 +02:00
|
|
|
#include "../../lv_examples.h"
|
2021-02-14 14:56:34 +01:00
|
|
|
#if LV_USE_CANVAS && LV_BUILD_EXAMPLES
|
2021-02-08 09:53:03 +01:00
|
|
|
|
|
|
|
|
|
|
|
#define CANVAS_WIDTH 200
|
|
|
|
#define CANVAS_HEIGHT 150
|
|
|
|
|
|
|
|
void lv_example_canvas_1(void)
|
|
|
|
{
|
|
|
|
lv_draw_rect_dsc_t rect_dsc;
|
|
|
|
lv_draw_rect_dsc_init(&rect_dsc);
|
|
|
|
rect_dsc.radius = 10;
|
|
|
|
rect_dsc.bg_opa = LV_OPA_COVER;
|
2023-07-05 13:05:19 +02:00
|
|
|
rect_dsc.bg_grad.dir = LV_GRAD_DIR_VER;
|
2022-01-11 12:38:30 +01:00
|
|
|
rect_dsc.bg_grad.stops[0].color = lv_palette_main(LV_PALETTE_RED);
|
2023-07-05 13:05:19 +02:00
|
|
|
rect_dsc.bg_grad.stops[0].opa = LV_OPA_100;
|
2022-01-11 12:38:30 +01:00
|
|
|
rect_dsc.bg_grad.stops[1].color = lv_palette_main(LV_PALETTE_BLUE);
|
2023-07-05 13:05:19 +02:00
|
|
|
rect_dsc.bg_grad.stops[1].opa = LV_OPA_50;
|
2021-02-08 09:53:03 +01:00
|
|
|
rect_dsc.border_width = 2;
|
|
|
|
rect_dsc.border_opa = LV_OPA_90;
|
2021-02-23 15:03:06 +01:00
|
|
|
rect_dsc.border_color = lv_color_white();
|
2021-02-08 09:53:03 +01:00
|
|
|
rect_dsc.shadow_width = 5;
|
|
|
|
rect_dsc.shadow_ofs_x = 5;
|
|
|
|
rect_dsc.shadow_ofs_y = 5;
|
|
|
|
|
|
|
|
lv_draw_label_dsc_t label_dsc;
|
|
|
|
lv_draw_label_dsc_init(&label_dsc);
|
2021-11-29 14:54:37 +01:00
|
|
|
label_dsc.color = lv_palette_main(LV_PALETTE_ORANGE);
|
2023-07-05 13:05:19 +02:00
|
|
|
label_dsc.text = "Some text on text canvas";
|
2021-02-08 09:53:03 +01:00
|
|
|
|
2022-10-11 20:17:11 +02:00
|
|
|
static uint8_t cbuf[LV_CANVAS_BUF_SIZE_TRUE_COLOR(CANVAS_WIDTH, CANVAS_HEIGHT)];
|
2021-02-08 09:53:03 +01:00
|
|
|
|
2021-03-25 13:36:50 +01:00
|
|
|
lv_obj_t * canvas = lv_canvas_create(lv_scr_act());
|
2023-02-20 20:50:58 +01:00
|
|
|
lv_canvas_set_buffer(canvas, cbuf, CANVAS_WIDTH, CANVAS_HEIGHT, LV_COLOR_FORMAT_NATIVE);
|
2021-03-25 16:14:17 +01:00
|
|
|
lv_obj_center(canvas);
|
2021-04-23 12:46:14 +02:00
|
|
|
lv_canvas_fill_bg(canvas, lv_palette_lighten(LV_PALETTE_GREY, 3), LV_OPA_COVER);
|
2021-02-08 09:53:03 +01:00
|
|
|
|
|
|
|
|
2023-07-05 13:05:19 +02:00
|
|
|
lv_layer_t layer;
|
|
|
|
lv_canvas_init_layer(canvas, &layer);
|
|
|
|
|
|
|
|
lv_area_t coords_rect = {30, 20, 100, 70};
|
|
|
|
lv_draw_rect(&layer, &rect_dsc, &coords_rect);
|
|
|
|
|
|
|
|
|
|
|
|
lv_area_t coords_text = {40, 80, 100, 120};
|
|
|
|
lv_draw_label(&layer, &label_dsc, &coords_text);
|
|
|
|
|
|
|
|
lv_canvas_finish_layer(canvas, &layer);
|
2021-02-08 09:53:03 +01:00
|
|
|
|
2022-01-17 14:10:23 +01:00
|
|
|
/*Test the rotation. It requires another buffer where the original image is stored.
|
2021-03-15 02:03:27 +08:00
|
|
|
*So copy the current image to buffer and rotate it to the canvas*/
|
2022-10-11 20:17:11 +02:00
|
|
|
static uint8_t cbuf_tmp[LV_CANVAS_BUF_SIZE_TRUE_COLOR(CANVAS_WIDTH, CANVAS_HEIGHT)];
|
2023-07-05 13:05:19 +02:00
|
|
|
lv_memcpy(cbuf_tmp, cbuf, sizeof(cbuf_tmp));
|
2021-02-08 09:53:03 +01:00
|
|
|
lv_img_dsc_t img;
|
|
|
|
img.data = (void *)cbuf_tmp;
|
2023-02-20 20:50:58 +01:00
|
|
|
img.header.cf = LV_COLOR_FORMAT_NATIVE;
|
2021-02-08 09:53:03 +01:00
|
|
|
img.header.w = CANVAS_WIDTH;
|
|
|
|
img.header.h = CANVAS_HEIGHT;
|
|
|
|
|
2023-07-05 13:05:19 +02:00
|
|
|
lv_canvas_finish_layer(canvas, &layer);
|
|
|
|
|
|
|
|
lv_canvas_fill_bg(canvas, lv_palette_lighten(LV_PALETTE_GREY, 1), LV_OPA_COVER);
|
|
|
|
|
|
|
|
lv_draw_img_dsc_t img_dsc;
|
|
|
|
lv_draw_img_dsc_init(&img_dsc);
|
|
|
|
img_dsc.angle = 120;
|
|
|
|
img_dsc.src = &img;
|
|
|
|
img_dsc.pivot.x = CANVAS_WIDTH / 2;
|
|
|
|
img_dsc.pivot.y = CANVAS_HEIGHT / 2;
|
|
|
|
|
|
|
|
lv_area_t coords_img = {0, 0, CANVAS_WIDTH - 1, CANVAS_HEIGHT - 1};
|
|
|
|
lv_draw_img(&layer, &img_dsc, &coords_img);
|
|
|
|
|
|
|
|
lv_canvas_finish_layer(canvas, &layer);
|
2021-02-08 09:53:03 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|