lv_image_decoder.h
Typedefs
-
typedef _lv_image_src_t lv_image_src_t
-
typedef lv_result_t (*lv_image_decoder_info_f_t)(struct _lv_image_decoder_t *decoder, const void *src, lv_image_header_t *header)
Get info from an image and store in the
header
- Param src:
the image source. Can be a pointer to a C array or a file name (Use
lv_image_src_get_type
to determine the type)- Param header:
store the info here
- Return:
LV_RESULT_OK: info written correctly; LV_RESULT_INVALID: failed
-
typedef lv_result_t (*lv_image_decoder_open_f_t)(struct _lv_image_decoder_t *decoder, struct _lv_image_decoder_dsc_t *dsc)
Open an image for decoding. Prepare it as it is required to read it later
- Param decoder:
pointer to the decoder the function associated with
- Param dsc:
pointer to decoder descriptor.
src
,color
are already initialized in it.
-
typedef lv_result_t (*lv_image_decoder_get_area_cb_t)(struct _lv_image_decoder_t *decoder, struct _lv_image_decoder_dsc_t *dsc, const lv_area_t *full_area, lv_area_t *decoded_area)
Decode
len
pixels starting from the givenx
,y
coordinates and store them inbuf
. Required only if the "open" function can't return with the whole decoded pixel array.- Param decoder:
pointer to the decoder the function associated with
- Param dsc:
pointer to decoder descriptor
- Param x:
start x coordinate
- Param y:
start y coordinate
- Param len:
number of pixels to decode
- Param buf:
a buffer to store the decoded pixels
- Return:
LV_RESULT_OK: ok; LV_RESULT_INVALID: failed
-
typedef void (*lv_image_decoder_close_f_t)(struct _lv_image_decoder_t *decoder, struct _lv_image_decoder_dsc_t *dsc)
Close the pending decoding. Free resources etc.
- Param decoder:
pointer to the decoder the function associated with
- Param dsc:
pointer to decoder descriptor
-
typedef struct _lv_image_decoder_t lv_image_decoder_t
-
typedef struct _lv_image_decoder_dsc_t lv_image_decoder_dsc_t
Describe an image decoding session. Stores data about the decoding
Enums
Functions
-
void _lv_image_decoder_init(void)
Initialize the image decoder module
-
lv_result_t lv_image_decoder_get_info(const void *src, lv_image_header_t *header)
Get information about an image. Try the created image decoder one by one. Once one is able to get info that info will be used.
- Parameters:
src -- the image source. Can be 1) File name: E.g. "S:folder/img1.png" (The drivers needs to registered via
lv_fs_drv_register()
) 2) Variable: Pointer to anlv_image_dsc_t
variable 3) Symbol: E.g.LV_SYMBOL_OK
header -- the image info will be stored here
- Returns:
LV_RESULT_OK: success; LV_RESULT_INVALID: wasn't able to get info about the image
-
lv_result_t lv_image_decoder_open(lv_image_decoder_dsc_t *dsc, const void *src, lv_color_t color, int32_t frame_id)
Open an image. Try the created image decoders one by one. Once one is able to open the image that decoder is saved in
dsc
- Parameters:
dsc -- describes a decoding session. Simply a pointer to an
lv_image_decoder_dsc_t
variable.src -- the image source. Can be 1) File name: E.g. "S:folder/img1.png" (The drivers needs to registered via
lv_fs_drv_register())
) 2) Variable: Pointer to anlv_image_dsc_t
variable 3) Symbol: E.g.LV_SYMBOL_OK
color -- The color of the image with
LV_IMAGE_CF_ALPHA_...
frame_id -- the index of the frame. Used only with animated images, set 0 for normal images
- Returns:
LV_RESULT_OK: opened the image.
dsc->img_data
anddsc->header
are set. LV_RESULT_INVALID: none of the registered image decoders were able to open the image.
-
lv_result_t lv_image_decoder_get_area(lv_image_decoder_dsc_t *dsc, const lv_area_t *full_area, lv_area_t *decoded_area)
Decode an area of the opened image
- Parameters:
dsc -- image decoder descriptor
full_area -- start X coordinate (from left)
decoded_area -- start Y coordinate (from top)
- Returns:
LV_RESULT_OK: success; LV_RESULT_INVALID: an error occurred
-
void lv_image_decoder_close(lv_image_decoder_dsc_t *dsc)
Close a decoding session
- Parameters:
dsc -- pointer to
lv_image_decoder_dsc_t
used inlv_image_decoder_open
-
lv_image_decoder_t *lv_image_decoder_create(void)
Create a new image decoder
- Returns:
pointer to the new image decoder
-
void lv_image_decoder_delete(lv_image_decoder_t *decoder)
Delete an image decoder
- Parameters:
decoder -- pointer to an image decoder
-
lv_image_decoder_t *lv_image_decoder_get_next(lv_image_decoder_t *decoder)
Get the next image decoder in the linked list of image decoders
- Parameters:
decoder -- pointer to an image decoder or NULL to get the first one
- Returns:
the next image decoder or NULL if no more image decoder exists
-
void lv_image_decoder_set_info_cb(lv_image_decoder_t *decoder, lv_image_decoder_info_f_t info_cb)
Set a callback to get information about the image
- Parameters:
decoder -- pointer to an image decoder
info_cb -- a function to collect info about an image (fill an
lv_image_header_t
struct)
-
void lv_image_decoder_set_open_cb(lv_image_decoder_t *decoder, lv_image_decoder_open_f_t open_cb)
Set a callback to open an image
- Parameters:
decoder -- pointer to an image decoder
open_cb -- a function to open an image
-
void lv_image_decoder_set_get_area_cb(lv_image_decoder_t *decoder, lv_image_decoder_get_area_cb_t read_line_cb)
Set a callback to a decoded line of an image
- Parameters:
decoder -- pointer to an image decoder
read_line_cb -- a function to read a line of an image
-
void lv_image_decoder_set_close_cb(lv_image_decoder_t *decoder, lv_image_decoder_close_f_t close_cb)
Set a callback to close a decoding session. E.g. close files and free other resources.
- Parameters:
decoder -- pointer to an image decoder
close_cb -- a function to close a decoding session
-
lv_result_t lv_image_decoder_built_in_info(lv_image_decoder_t *decoder, const void *src, lv_image_header_t *header)
Get info about a built-in image
- Parameters:
decoder -- the decoder where this function belongs
src -- the image source: pointer to an
lv_image_dsc_t
variable, a file path or a symbolheader -- store the image data here
- Returns:
LV_RESULT_OK: the info is successfully stored in
header
; LV_RESULT_INVALID: unknown format or other error.
-
lv_result_t lv_image_decoder_built_in_get_area(lv_image_decoder_t *decoder, lv_image_decoder_dsc_t *dsc, const lv_area_t *full_area, lv_area_t *decoded_area)
-
lv_result_t lv_image_decoder_built_in_open(lv_image_decoder_t *decoder, lv_image_decoder_dsc_t *dsc)
Open a built in image
- Parameters:
decoder -- the decoder where this function belongs
dsc -- pointer to decoder descriptor.
src
,style
are already initialized in it.
- Returns:
LV_RESULT_OK: the info is successfully stored in
header
; LV_RESULT_INVALID: unknown format or other error.
-
void lv_image_decoder_built_in_close(lv_image_decoder_t *decoder, lv_image_decoder_dsc_t *dsc)
Close the pending decoding. Free resources etc.
- Parameters:
decoder -- pointer to the decoder the function associated with
dsc -- pointer to decoder descriptor
-
struct _lv_image_decoder_t
Public Members
-
lv_image_decoder_info_f_t info_cb
-
lv_image_decoder_open_f_t open_cb
-
lv_image_decoder_get_area_cb_t get_area_cb
-
lv_image_decoder_close_f_t close_cb
-
void *user_data
-
lv_image_decoder_info_f_t info_cb
-
struct _lv_image_decoder_dsc_t
- #include <lv_image_decoder.h>
Describe an image decoding session. Stores data about the decoding
Public Members
-
lv_image_decoder_t *decoder
The decoder which was able to open the image source
-
const void *src
The image source. A file path like "S:my_img.png" or pointer to an
lv_image_dsc_t
variable
-
int32_t frame_id
Frame of the image, using with animated images
-
lv_image_src_t src_type
Type of the source: file or variable. Can be set in
open
function if required
-
lv_image_header_t header
Info about the opened image: color format, size, etc. MUST be set in
open
function
-
const uint8_t *img_data
Pointer to a buffer where the image's data (pixels) are stored in a decoded, plain format. MUST be set in
open
function
-
const lv_color32_t *palette
-
uint32_t palette_size
-
uint32_t time_to_open
How much time did it take to open the image. [ms] If not set
lv_image_cache
will measure and set the time to open
-
const char *error_msg
A text to display instead of the image when the image can't be opened. Can be set in
open
function or set NULL.
-
struct _lv_cache_entry_t *cache_entry
Point to cache entry information
-
void *user_data
Store any custom data here is required
-
lv_image_decoder_t *decoder