GIF decoder(GIF解码器)

显示原文

Allow using GIF images in LVGL.

Detailed introduction: https://github.com/lecram/gifdec

When enabled in lv_conf.h with LV_USE_GIF lv_gif_create(parent) can be used to create a gif widget.

lv_gif_set_src(widget, src) works very similarly to lv_image_set_src(). As source, it also accepts images as variables (lv_image_dsc_t) or files.


GIF解码器让我们可以在 LVGL 中使用 GIF 图像。

详细介绍: https://github.com/lecram/gifdec

如果在 lv_conf.h 中启用了 LV_USE_GIF ,那么可以使用 lv_gif_create(parent) 创建 gif 控件,这与 lv_img_create 非常相似。

lv_gif_set_src(widget, src) 的工作方式与 lv_image_set_src() 非常相似。作为源,它还接受图像作为变量 (lv_image_dsc_t) 或文件。

Convert GIF files to C array(将 GIF 文件转换为 C 数组)

显示原文

To convert a GIF file to byte values array use LVGL's online converter. Select "Raw" color format and "C array" Output format.


要将 GIF 文件转换为字节值的数组,请使用 LVGL的在线转换器。选择 “RAW” 颜色格式和 “C array” 输出格式。

Use GIF images from file(使用GIF文件)

显示原文

For example:

lv_gif_set_src(widget, "S:path/to/example.gif");

Note that, a file system driver needs to be registered to open images from files. Read more about it File system(文件系统) or just enable one in lv_conf.h with LV_USE_FS_...


示例:

lv_gif_set_src(widget, "S:path/to/example.gif");

注意,需要注册文件系统驱动程序才能从文件中打开图像。阅读 File system(文件系统) 关于文件系统的更多信息,或直接在 lv_conf.h 中打开其中一个类似 LV_USE_FS_... 的宏。

Memory requirements(内存要求)

显示原文

To decode and display a GIF animation the following amount of RAM is required:

  • LV_COLOR_DEPTH 8: 3 x image width x image height

  • LV_COLOR_DEPTH 16: 4 x image width x image height

  • LV_COLOR_DEPTH 32: 5 x image width x image height


要解码并显示 GIF 动画,所需的 RAM 数量如下:

  • LV_COLOR_DEPTH 8: 3 x 图像宽度 x 图像高度

  • LV_COLOR_DEPTH 16: 4 x 图像宽度 x 图像高度

  • LV_COLOR_DEPTH 32: 5 x 图像宽度 x 图像高度

Example

Open a GIF image from file and variable

#include "../../lv_examples.h"
#if LV_USE_GIF && LV_BUILD_EXAMPLES

/**
 * Open a GIF image from a file and a variable
 */
void lv_example_gif_1(void)
{
    LV_IMAGE_DECLARE(img_bulb_gif);
    lv_obj_t * img;

    img = lv_gif_create(lv_screen_active());
    lv_gif_set_src(img, &img_bulb_gif);
    lv_obj_align(img, LV_ALIGN_LEFT_MID, 20, 0);

    img = lv_gif_create(lv_screen_active());
    /* Assuming a File system is attached to letter 'A'
     * E.g. set LV_USE_FS_STDIO 'A' in lv_conf.h */
    lv_gif_set_src(img, "A:lvgl/examples/libs/gif/bulb.gif");
    lv_obj_align(img, LV_ALIGN_RIGHT_MID, -20, 0);
}

#endif

API

gifdec.h

lv_gif.h

lv_types.h