feat(draw): add implements vector graphic APIs (#4528) (#4691)

Signed-off-by: zhangjipeng <zhangjipeng@xiaomi.com>
Co-authored-by: zhangjipeng <zhangjipeng@xiaomi.com>
Co-authored-by: Gabor Kiss-Vamosi <kisvegabor@gmail.com>
This commit is contained in:
Zhang Ji Peng
2023-11-09 18:37:33 +08:00
committed by GitHub
parent 3bb649db7f
commit 8cf0bbb558
108 changed files with 30939 additions and 12 deletions
+5
View File
@@ -92,10 +92,15 @@ static const demo_entry_info_t demos_entry_info[] = {
{ "scroll", .entry_cb = lv_demo_scroll },
#endif
#if LV_USE_DEMO_VECTOR_GRAPHIC && LV_USE_VECTOR_GRAPHIC
{ "vector_graphic", .entry_cb = lv_demo_vector_graphic },
#endif
//#if LV_USE_DEMO_BENCHMARK
// { DEMO_BENCHMARK_NAME, .entry_benchmark_cb = lv_demo_benchmark, 1 },
// { DEMO_BENCHMARK_SCENE_NAME, .entry_benchmark_scene_cb = lv_demo_benchmark_run_scene, 2 },
//#endif
{ "", .entry_cb = NULL }
};
+4
View File
@@ -51,6 +51,10 @@ extern "C" {
#include "multilang/lv_demo_multilang.h"
#endif
#if LV_USE_DEMO_VECTOR_GRAPHIC && LV_USE_VECTOR_GRAPHIC && (LV_USE_THORVG_INTERNAL || LV_USE_THORVG_EXTERNAL)
#include "vector_graphic/lv_demo_vector_graphic.h"
#endif
#if LV_USE_DEMO_RENDER
#include "render/lv_demo_render.h"
#endif
File diff suppressed because one or more lines are too long
@@ -0,0 +1,245 @@
/**
* @file lv_demo_vector_graphic.c
*
*/
/*********************
* INCLUDES
*********************/
#include "lv_demo_vector_graphic.h"
#if LV_USE_DEMO_VECTOR_GRAPHIC
/*********************
* DEFINES
*********************/
#define WIDTH 640
#define HEIGHT 480
/**********************
* TYPEDEFS
**********************/
/**********************
* STATIC PROTOTYPES
**********************/
static void draw_pattern(lv_vector_dsc_t * ctx, lv_vector_path_t * path)
{
lv_vector_path_clear(path);
lv_vector_dsc_identity(ctx);
lv_fpoint_t pts[] = {{200, 200}, {300, 200}, {300, 300}, {200, 300}};
lv_vector_path_move_to(path, &pts[0]);
lv_vector_path_line_to(path, &pts[1]);
lv_vector_path_quad_to(path, &pts[2], &pts[3]);
lv_vector_path_close(path);
lv_draw_image_dsc_t img_dsc;
lv_draw_image_dsc_init(&img_dsc);
LV_IMAGE_DECLARE(img_demo_vector_avatar);
img_dsc.header = img_demo_vector_avatar.header;
img_dsc.src = &img_demo_vector_avatar;
lv_vector_dsc_set_fill_image(ctx, &img_dsc);
lv_vector_dsc_translate(ctx, 250, 250);
lv_vector_dsc_rotate(ctx, 25);
lv_vector_dsc_translate(ctx, -250, -250);
lv_vector_dsc_add_path(ctx, path); // draw a path
}
static void draw_gradient(lv_vector_dsc_t * ctx, lv_vector_path_t * path)
{
lv_vector_path_clear(path);
lv_vector_dsc_identity(ctx);
lv_fpoint_t pts[] = {{400, 200}, {600, 200}, {400, 400}};
lv_vector_path_move_to(path, &pts[0]);
lv_vector_path_quad_to(path, &pts[1], &pts[2]);
lv_vector_path_close(path);
lv_grad_dsc_t grad;
grad.dir = LV_GRAD_DIR_HOR;
grad.stops_count = 2;
grad.stops[0].color = lv_color_hex(0xff0000);
grad.stops[0].opa = LV_OPA_COVER;
grad.stops[0].frac = 0;
grad.stops[1].color = lv_color_hex(0x00ff00);
grad.stops[1].opa = LV_OPA_COVER;
grad.stops[1].frac = 255;
// grad.stops[2].color = lv_color_hex(0x0000ff);
// grad.stops[2].opa = LV_OPA_COVER;
// grad.stops[2].frac = 255;
lv_matrix_t mt;
lv_matrix_identity(&mt);
lv_matrix_rotate(&mt, 30);
lv_vector_dsc_set_fill_transform(ctx, &mt);
lv_vector_dsc_set_fill_linear_gradient(ctx, &grad, LV_VECTOR_GRADIENT_SPREAD_PAD);
lv_vector_dsc_add_path(ctx, path); // draw a path
}
static void draw_radial_gradient(lv_vector_dsc_t * ctx, lv_vector_path_t * path)
{
lv_vector_path_clear(path);
lv_vector_dsc_identity(ctx);
lv_fpoint_t pts[] = {{400, 50}, {500, 50}, {500, 200}, {400, 200}};
lv_vector_path_move_to(path, &pts[0]);
lv_vector_path_line_to(path, &pts[1]);
lv_vector_path_line_to(path, &pts[2]);
lv_vector_path_line_to(path, &pts[3]);
lv_vector_path_close(path);
lv_grad_dsc_t grad;
grad.dir = LV_GRAD_DIR_HOR;
grad.stops_count = 2;
grad.stops[0].color = lv_color_hex(0xff0000);
grad.stops[0].opa = LV_OPA_COVER;
grad.stops[0].frac = 0;
grad.stops[1].color = lv_color_hex(0x0000ff);
grad.stops[1].opa = LV_OPA_COVER;
grad.stops[1].frac = 255;
// grad.stops[2].color = lv_color_hex(0x0000ff);
// grad.stops[2].opa = LV_OPA_COVER;
// grad.stops[2].frac = 255;
lv_vector_dsc_set_fill_radial_gradient(ctx, &grad, 50, 50, 20, LV_VECTOR_GRADIENT_SPREAD_REFLECT);
lv_vector_dsc_add_path(ctx, path); // draw a path
}
static void draw_shapes(lv_vector_dsc_t * ctx, lv_vector_path_t * path)
{
lv_vector_path_clear(path);
lv_vector_dsc_identity(ctx);
lv_fpoint_t pts[] = {{50, 50}, {200, 200}, {50, 200}};
lv_vector_path_move_to(path, &pts[0]);
lv_vector_path_line_to(path, &pts[1]);
lv_vector_path_line_to(path, &pts[2]);
lv_vector_path_close(path);
lv_vector_dsc_set_fill_color(ctx, lv_color_make(0xFF, 0x00, 0x00));
lv_vector_dsc_scale(ctx, 0.5, 0.5);
lv_vector_dsc_add_path(ctx, path); // draw a path
lv_vector_path_clear(path);
lv_vector_dsc_identity(ctx);
lv_area_t rect = {300, 300, 400, 400};
lv_vector_path_append_rect(path, &rect, 50, 60);
lv_vector_dsc_set_fill_color(ctx, lv_color_make(0x00, 0x80, 0xff));
lv_vector_dsc_skew(ctx, 5, 0);
lv_vector_dsc_add_path(ctx, path); // draw a path
lv_vector_path_clear(path);
lv_vector_dsc_identity(ctx);
lv_area_t rect2 = {100, 300, 200, 400};
lv_vector_path_append_rect(path, &rect2, 10, 10);
lv_vector_dsc_set_fill_color(ctx, lv_color_make(0x80, 0x00, 0x80));
lv_vector_path_t * path2 = lv_vector_path_create(LV_VECTOR_PATH_QUALITY_MEDIUM);
lv_fpoint_t p = {50, 420};
lv_vector_path_append_circle(path2, &p, 50, 30);
lv_vector_path_append_path(path, path2);
lv_vector_dsc_add_path(ctx, path); // draw a path
lv_vector_path_delete(path2);
}
static void draw_lines(lv_vector_dsc_t * ctx, lv_vector_path_t * path)
{
lv_vector_path_clear(path);
lv_vector_dsc_identity(ctx);
lv_fpoint_t pts[] = {{50, 50}, {200, 200}, {250, 300}, {350, 150}};
lv_vector_path_move_to(path, &pts[0]);
lv_vector_path_cubic_to(path, &pts[1], &pts[2], &pts[3]);
lv_vector_dsc_set_stroke_color(ctx, lv_color_make(0x00, 0xff, 0x00));
lv_vector_dsc_set_stroke_opa(ctx, LV_OPA_COVER);
lv_vector_dsc_set_fill_opa(ctx, LV_OPA_0);
lv_vector_dsc_set_stroke_width(ctx, 8.0f);
float dashes[] = {10, 15, 20, 12};
lv_vector_dsc_set_stroke_dash(ctx, dashes, 4);
lv_vector_dsc_add_path(ctx, path); // draw a path
lv_vector_dsc_set_stroke_opa(ctx, LV_OPA_0);
lv_vector_dsc_set_fill_opa(ctx, LV_OPA_COVER);
}
static void draw_blend(lv_vector_dsc_t * ctx, lv_vector_path_t * path)
{
lv_vector_path_clear(path);
lv_vector_dsc_identity(ctx);
lv_fpoint_t pts[] = {{200, 200}, {400, 200}, {450, 350}, {350, 150}};
lv_vector_path_move_to(path, &pts[0]);
lv_vector_path_cubic_to(path, &pts[1], &pts[2], &pts[3]);
lv_vector_path_close(path);
lv_vector_dsc_set_fill_color(ctx, lv_color_make(0xFF, 0x00, 0xFF));
lv_vector_dsc_set_blend_mode(ctx, LV_VECTOR_BLEND_SCREEN);
lv_vector_dsc_add_path(ctx, path); // draw a path
}
static void draw_vector(lv_layer_t * layer)
{
lv_vector_dsc_t * ctx = lv_vector_dsc_create(layer);
lv_area_t rect = {0, 100, 300, 300};
lv_vector_dsc_set_fill_color(ctx, lv_color_lighten(lv_color_black(), 50));
lv_vector_clear_area(ctx, &rect); // clear screen
lv_vector_path_t * path = lv_vector_path_create(LV_VECTOR_PATH_QUALITY_MEDIUM);
draw_shapes(ctx, path);
draw_lines(ctx, path);
draw_pattern(ctx, path);
draw_radial_gradient(ctx, path);
draw_gradient(ctx, path);
draw_blend(ctx, path);
lv_draw_vector(ctx); // submit draw
lv_vector_path_delete(path);
lv_vector_dsc_delete(ctx);
}
/**********************
* STATIC VARIABLES
**********************/
/**********************
* MACROS
**********************/
/**********************
* GLOBAL FUNCTIONS
**********************/
void lv_demo_vector_graphic(void)
{
static uint8_t canvas_buf[WIDTH * HEIGHT * 4];
lv_obj_t * canvas = lv_canvas_create(lv_scr_act());
lv_canvas_set_buffer(canvas, canvas_buf, WIDTH, HEIGHT, LV_COLOR_FORMAT_ARGB8888);
lv_layer_t layer;
lv_canvas_init_layer(canvas, &layer);
draw_vector(&layer);
lv_canvas_finish_layer(canvas, &layer);
}
/**********************
* STATIC FUNCTIONS
**********************/
#endif
@@ -0,0 +1,40 @@
/**
* @file lv_demo_vector_graphic.h
*
*/
#ifndef LV_DEMO_VECTOR_GRAPHIC_H
#define LV_DEMO_VECTOR_GRAPHIC_H
#ifdef __cplusplus
extern "C" {
#endif
/*********************
* INCLUDES
*********************/
#include "../lv_demos.h"
/*********************
* DEFINES
*********************/
/**********************
* TYPEDEFS
**********************/
/**********************
* GLOBAL PROTOTYPES
**********************/
void lv_demo_vector_graphic(void);
/**********************
* MACROS
**********************/
#ifdef __cplusplus
} /* extern "C" */
#endif
#endif /*LV_DEMO_VECTOR_GRAPHIC_H*/