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;
|
2023-10-31 19:10:02 +01:00
|
|
|
rect_dsc.shadow_offset_x = 5;
|
|
|
|
rect_dsc.shadow_offset_y = 5;
|
2021-02-08 09:53:03 +01:00
|
|
|
|
|
|
|
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";
|
2023-11-18 15:33:58 +01:00
|
|
|
/*Create a buffer for the canvas*/
|
2023-12-17 16:14:33 +08:00
|
|
|
LV_DRAW_BUF_DEFINE(draw_buf_16bpp, CANVAS_WIDTH, CANVAS_HEIGHT, LV_COLOR_FORMAT_RGB565);
|
2021-02-08 09:53:03 +01:00
|
|
|
|
2023-10-12 20:37:27 +02:00
|
|
|
lv_obj_t * canvas = lv_canvas_create(lv_screen_active());
|
2023-12-17 16:14:33 +08:00
|
|
|
lv_canvas_set_draw_buf(canvas, &draw_buf_16bpp);
|
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.
|
2023-12-17 16:14:33 +08:00
|
|
|
*So use previous canvas as image and rotate it to the new canvas*/
|
|
|
|
LV_DRAW_BUF_DEFINE(draw_buf_32bpp, CANVAS_WIDTH, CANVAS_HEIGHT, LV_COLOR_FORMAT_ARGB8888);
|
2023-11-18 15:33:58 +01:00
|
|
|
/*Create a canvas and initialize its palette*/
|
|
|
|
canvas = lv_canvas_create(lv_screen_active());
|
2023-12-17 16:14:33 +08:00
|
|
|
lv_canvas_set_draw_buf(canvas, &draw_buf_32bpp);
|
2023-11-18 15:33:58 +01:00
|
|
|
lv_canvas_fill_bg(canvas, lv_color_hex3(0xccc), LV_OPA_COVER);
|
|
|
|
lv_obj_center(canvas);
|
|
|
|
|
2023-07-05 13:05:19 +02:00
|
|
|
lv_canvas_fill_bg(canvas, lv_palette_lighten(LV_PALETTE_GREY, 1), LV_OPA_COVER);
|
|
|
|
|
2023-12-17 16:14:33 +08:00
|
|
|
lv_canvas_init_layer(canvas, &layer);
|
|
|
|
lv_image_dsc_t img;
|
|
|
|
lv_draw_buf_to_image(&draw_buf_16bpp, &img);
|
2023-09-14 20:12:31 +02:00
|
|
|
lv_draw_image_dsc_t img_dsc;
|
|
|
|
lv_draw_image_dsc_init(&img_dsc);
|
2023-09-18 22:57:30 +02:00
|
|
|
img_dsc.rotation = 120;
|
2023-07-05 13:05:19 +02:00
|
|
|
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};
|
2023-09-14 20:12:31 +02:00
|
|
|
lv_draw_image(&layer, &img_dsc, &coords_img);
|
2023-07-05 13:05:19 +02:00
|
|
|
|
|
|
|
lv_canvas_finish_layer(canvas, &layer);
|
2021-02-08 09:53:03 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|