06 LVGL渐变样式

这段代码初始化了一个静态样式结构体,设置了圆角、不透明度、背景颜色和渐变。它创建了一个垂直渐变,从浅红色到蓝色,并将渐变向底部偏移。最后,使用这个样式创建了一个200x500像素的对象,并居中显示在屏幕上。
摘要由CSDN通过智能技术生成

在这里插入图片描述

void lv_100ask_demo_course_2_1_1(void)
 
{
    static lv_style_t style;
    lv_style_init(&style);
    lv_style_set_radius(&style, 5);

    /*Make a gradient*/
    lv_style_set_bg_opa(&style, LV_OPA_COVER);
    lv_style_set_bg_color(&style, lv_palette_lighten(LV_PALETTE_RED, 1));
    lv_style_set_bg_grad_color(&style, lv_palette_main(LV_PALETTE_BLUE));
    lv_style_set_bg_grad_dir(&style, LV_GRAD_DIR_VER);

    /*Shift the gradient to the bottom*/
    lv_style_set_bg_main_stop(&style, 0);  //样式起点
    lv_style_set_bg_grad_stop(&style, 500);//样式结束位置

    /*Create an object with the new style*/
    lv_obj_t * obj = lv_obj_create(lv_scr_act());
    lv_obj_add_style(obj, &style, 0); //为对象增加 样式
    lv_obj_set_size(obj,200,500);  //设置对象 宽高
    lv_obj_center(obj);
}
你可以使用 LVGL(Light and Versatile Graphics Library)来创建渐变效果的进度条。下面是一个使用 LVGL 创建渐变进度条的示例代码: ```c /* 创建一个父容器 */ lv_obj_t *parent = lv_cont_create(lv_scr_act(), NULL); lv_obj_set_size(parent, 200, 30); lv_obj_center(parent); /* 创建一个背景样式 */ static lv_style_t bg_style; lv_style_init(&bg_style); lv_style_set_bg_color(&bg_style, lv_color_hex(0xCCCCCC)); /* 创建一个进度条 */ lv_obj_t *progress_bar = lv_bar_create(parent, NULL); lv_obj_set_size(progress_bar, 180, 20); lv_obj_align(progress_bar, parent, LV_ALIGN_CENTER, 0, 0); lv_bar_set_range(progress_bar, 0, 100); // 设置进度条的范围 lv_bar_set_value(progress_bar, 40, LV_ANIM_ON); // 设置进度条的当前值,并启用动画 /* 创建一个前景样式 */ static lv_style_t fg_style; lv_style_init(&fg_style); lv_style_set_bg_color(&fg_style, lv_color_hex(0xFF0000)); // 设置前景样式为红色 /* 创建一个渐变样式 */ static lv_style_t grad_style; lv_style_init(&grad_style); lv_style_set_bg_grad_color(&grad_style, lv_color_hex(0xFF0000), lv_color_hex(0x00FF00), LV_GRAD_DIR_HOR); // 设置渐变色为红到绿的水平渐变 /* 应用样式到进度条 */ lv_bar_set_style(progress_bar, LV_BAR_STYLE_BG, &bg_style); lv_bar_set_style(progress_bar, LV_BAR_STYLE_INDIC, &grad_style); while (1) { lv_task_handler(); /* 持续更新界面 */ usleep(5000); } ``` 这个示例代码中,我们创建了一个父容器和一个进度条。我们设置进度条的范围为0到100,并将当前值设置为40,启用动画。然后,我们创建了背景样式和前景样式,并使用渐变样式设置进度条的渐变效果。最后,我们将样式应用到进度条上,并使用 `lv_task_handler()` 函数来持续更新界面。 请注意,这只是一个简单的示例代码,你可以根据自己的需求进行修改和扩展。希望对你有帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值