lvgl - LVGL Image Library#

Adapted Air780E/Air700E Air780EP/Air780EPV Air601 Air101/Air103 Air105 ESP32C3 ESP32S3

Tip

This library has its own demo,click this link to view the demo example of lvgl

lvgl.draw_mask_radius_param_t()#

Create a lv_draw_mask_radius_param_t

Parameters

None

Return Value

return value type

explanation

userdata

lv_draw_mask_radius_param_t Pointer

Examples

local radius = lvgl.draw_mask_radius_param_t()

lvgl.draw_mask_radius_param_t_free(radius)#

Release one.lv_draw_mask_radius_param_t

Parameters

None

Return Value

None

Examples

local lvgl.draw_mask_radius_param_t_free(radius)

lvgl.draw_mask_line_param_t()#

Create a lv_draw_mask_line_param_t

Parameters

None

Return Value

return value type

explanation

userdata

lv_draw_mask_line_param_t Pointer

Examples

local line = lvgl.draw_mask_line_param_t()

lvgl.draw_mask_line_param_t_free(line)#

Release one.lv_draw_mask_line_param_t

Parameters

None

Return Value

None

Examples

local lvgl.draw_mask_line_param_t_free(line)

lvgl.draw_mask_fade_param_t()#

Create a lv_draw_mask_fade_param_t

Parameters

None

Return Value

return value type

explanation

userdata

lv_draw_mask_fade_param_t Pointer

Examples

local fade = lvgl.draw_mask_fade_param_t()

lvgl.draw_mask_fade_param_t_free(fade)#

Release one.lv_draw_mask_fade_param_t

Parameters

None

Return Value

None

Examples

local lvgl.draw_mask_fade_param_t_free(fade)

lvgl.font_get(name)#

Get Built-in Font

Parameters

Incoming Value Type

Explanation

string

Font name font size, for example opposans_m_10

Return Value

return value type

explanation

userdata

Font Pointer

Examples

local font = lvgl.font_get("opposans_m_12")

lvgl.font_load(path/spi_device,size,bpp,thickness,cache_size,sty_zh,sty_en)#

Loading fonts from the file system

Parameters

Incoming Value Type

Explanation

string/userdata

Font path/spi_device (spi_device to use an external Qualcomm vector font chip)

number

size Optional, font size 16-192 defaults to 16 (use Qualcomm vector font)

number

bpp Optional Depth Default 4 (Use Qualcomm Vector Font)

number

thickness Optional weight value Default size * bpp (use Qualcomm vector font)

number

cache_size Optional default 0 (use Qualcomm vector font)

number

sty_zh OPTIONAL SELECT FONT DEFAULT 1 (USING QUALCOMM VECTOR FONT)

number

sty_en OPTIONAL SELECT FONT DEFAULT 3 (USING QUALCOMM VECTOR FONT)

Return Value

return value type

explanation

userdata

Font Pointer

Examples

local font = lvgl.font_load("/font_32.bin")
--local font = lvgl.font_load(spi_device,16)(Qualcomm Vector Font)

lvgl.font_free(font)#

Release the font and use it with caution!!! Only fonts loaded by font_load are allowed to be unloaded, and fonts obtained by font_get are not allowed to be unloaded

Parameters

Incoming Value Type

Explanation

string

Font Path

Return Value

return value type

explanation

userdata

Font Pointer

Examples

local font = lvgl.font_load("/font_32.bin")
-- N N N N Operation
-- Make sure the font is not used, not referenced, and the memory is tight and needs to be released.
lvgl.font_free(font)

lvgl.obj_set_event_cb(obj, func)#

Set event callbacks for components

Parameters

Incoming Value Type

Explanation

userdata

lvgl Component Pointer

func

lua Function, there are 2 parameters (obj, event), where obj is the current object, event is the event type, which is integer

Return Value

return value type

explanation

nil

No return value

Examples

None


lvgl.obj_set_signal_cb(obj, func)#

Set signal callbacks for components

Parameters

Incoming Value Type

Explanation

userdata

lvgl Component Pointer

func

lua Function, there are 2 parameters (obj, signal), where obj is the current object, signal is the signal type, is integer

Return Value

return value type

explanation

nil

No return value

Examples

None


lvgl.anim_set_exec_cb(anim, func)#

Set Animation Callback

Parameters

Incoming Value Type

Explanation

userdata

Animated Pointer

userdata

lvgl Component Pointer

func

lua Function, there are 2 parameters (obj, value), where obj is the current object, signal is the signal type, is integer

Return Value

return value type

explanation

nil

No return value

Examples

None


lvgl.anim_set_ready_cb(anim, func)#

Set Animation Callback

Parameters

Incoming Value Type

Explanation

userdata

Animated Pointer

userdata

lvgl Component Pointer

func

lua function with 1 argument (anim), where anim is the current object

Return Value

return value type

explanation

nil

No return value

Examples

None


lvgl.anim_path_set_cb(path, func)#

Set Animation Callback

Parameters

Incoming Value Type

Explanation

userdata

Animated Pointer

userdata

lvgl Component Pointer

func

lua function with 1 parameter (path), where path is the current object

Return Value

return value type

explanation

nil

No return value

Examples

None


lvgl.event_send(obj, ent)#

Send events to components

Parameters

Incoming Value Type

Explanation

userdata

Component Pointer

int

event id, for example lvgl.EVENT_PRESSED

Return Value

return value type

explanation

bool

Returns true on success, false if the object has been deleted, or nil

int

The underlying return value, if obj is nil nil

Examples

None


lvgl.scr_act()#

Get the currently active screen object

Parameters

None

Return Value

return value type

explanation

pointer

screen pointer

Examples

local scr = lvgl.scr_act()

lvgl.layer_top()#

Get layer_top

Parameters

None

Return Value

return value type

explanation

pointer

layer pointer

Examples

None


lvgl.layer_sys()#

Get layer_sys

Parameters

None

Return Value

return value type

explanation

pointer

layer pointer

Examples

None


lvgl.scr_load(scr)#

Load the specified screen

Parameters

Incoming Value Type

Explanation

userdata

screen Pointer

Return Value

None

Examples

    local scr = lvgl.obj_create(nil, nil)
    local btn = lvgl.btn_create(scr)
    lvgl.obj_align(btn, lvgl.scr_act(), lvgl.ALIGN_CENTER, 0, 0)
    local label = lvgl.label_create(btn)
    lvgl.label_set_text(label, "LuatOS!")
    lvgl.scr_load(scr)

lvgl.scr_load_anim(scr)#

Load the specified screen and use the specified transition animation

Parameters

Incoming Value Type

Explanation

userdata

screen Pointer

Return Value

None

Examples

    local scr = lvgl.obj_create(nil, nil)
    local btn = lvgl.btn_create(scr)
    lvgl.obj_align(btn, lvgl.scr_act(), lvgl.ALIGN_CENTER, 0, 0)
    local label = lvgl.label_create(btn)
    lvgl.label_set_text(label, "LuatOS!")

    local scr2 = lvgl.obj_create(nil,nil)
    local btn2 = lvgl.btn_create(scr2)
    lvgl.obj_align(btn, scr2, lvgl.ALIGN_CENTER, 0, 20)
    local label2 = lvgl.label_create(btn2)
    lvgl.label_set_text(label2, "Btn2")
    lvgl.scr_load(scr)
    --sys.wait(1000);
    lvgl.scr_load_anim(scr2,lvgl.SCR_LOAD_ANIM_OVER_LEFT,100,100,false)
primitive function:lv_scr_load_anim(lv_obj_t * new_scr, lv_scr_load_anim_t anim_type, uint32_t time, uint32_t delay, bool auto_del)


lvgl.theme_set_act(name)#

Set Theme

Parameters

Incoming Value Type

Explanation

string

Subject name, optional values are default/mono/empty/material_light/material_dark/material_no_transition/material_no_focus

Return Value

return value type

explanation

bool

Returns true on success, otherwise nil

Examples

-- Black and White Theme
lvgl.theme_set_act("mono")
-- Blank Theme
lvgl.theme_set_act("empty")

lvgl.sleep(enable)#

LVGL Sleep control, pause/resume refresh timer, currently only 105 and EC618 can be used

Parameters

Incoming Value Type

Explanation

boolean

true Pause False Resume

Return Value

None

Examples

lvgl.sleep(true)        --Pause refresh, system can sleep
lvgl.sleep(false)        --Resume refresh, system does not sleep

lvgl.init(w, h, lcd, buff_size, buff_mode)#

Initialization LVGL

Parameters

Incoming Value Type

Explanation

int

screen width, optional, taken from LCD by default

int

Screen height, optional, default from LCD

userdata

lcd pointer, optional, default value after LCD initialization, reserved multi-screen entry

int

Buffer size, default width * 10, without color depth.

int

Buffer mode, default 0, single buff mode, optional 1, double buff mode

Return Value

return value type

explanation

bool

Returns true on success, otherwise false

Examples

None


lvgl.anim_create()#

Create and initialize a anim

Parameters

None

Return Value

return value type

explanation

userdata

anim Pointer

Examples

local anim = lvgl.anim_create()

lvgl.anim_free(anim)#

Release one.anim

Parameters

None

Return Value

None

Examples

local lvgl.anim_free(anim)

lvgl.anim_path_t()#

Create a lv_anim_path_t

Parameters

None

Return Value

return value type

explanation

userdata

lv_anim_path_t Pointer

Examples

local anim_path_t = lvgl.anim_path_t()

lvgl.anim_path_t_free(anim_path_t)#

Release one.lv_anim_path_t

Parameters

None

Return Value

None

Examples

local lvgl.anim_path_t_free(anim_path_t)

lvgl.anim_set_path_str(anim, tp)#

Set the animation path method

Parameters

Incoming Value Type

Explanation

userdata

Animated Pointer

string

types, support linear/ease_in/ease_out/ease_in_out/overshoot/bounce/step

Return Value

return value type

explanation

nil

No return value

Examples

None


lvgl.qrcode_create(parent, size, dark_color, light_color)#

Create the qrcode component

Parameters

Incoming Value Type

Explanation

userdata

Parent Component

int

length, because qrcode is square

int

Color of data points in QR code, RGB color, default 0x3333ff

int

The color of the back scenic spot in the two-dimensional code, RGB color, default 0xeeeeff

Return Value

return value type

explanation

userdata

qrcode Components

Examples

-- Create and display qrcode
local qrcode = lvgl.qrcode_create(scr, 100)
lvgl.qrcode_update(qrcode, "https://luatos.com")
lvgl.obj_align(qrcode, lvgl.scr_act(), lvgl.ALIGN_CENTER, -100, -100)

lvgl.qrcode_update(qrcode, cnt)#

set the qrcode component’s qr code content and use it with the qrcode_create

Parameters

Incoming Value Type

Explanation

userdata

qrcode components, created by qrcode_create

string

Content data of two-dimensional code

Return Value

return value type

explanation

bool

If the update is successful, it returns true, otherwise it returns false. It is usually returned only if the data is too long to accommodate.false

Examples

None


lvgl.qrcode_delete(qrcode)#

Remove qrcode component

Parameters

Incoming Value Type

Explanation

userdata

qrcode components, created by qrcode_create

Return Value

return value type

explanation

nil

No return value

Examples

None


lvgl.style_t()#

Create a style

Parameters

None

Return Value

return value type

explanation

userdata

style Pointer

Examples

local style = lvgl.style_t()
lvgl.style_init(style)

lvgl.style_create()#

Create a style and initialize

Parameters

None

Return Value

return value type

explanation

userdata

style Pointer

Examples

local style = lvgl.style_create()

lvgl.style_list_create()#

Create a style_list

Parameters

None

Return Value

return value type

explanation

userdata

style Pointer

Examples

local style_list = lvgl.style_list_create()

lvgl.style_list_t()#

Create a style_list

Parameters

None

Return Value

return value type

explanation

userdata

style Pointer

Examples

local style = lvgl.style_list_t()

lvgl.style_delete(style)#

Delete style, use caution, usually do not perform delete operation

Parameters

Incoming Value Type

Explanation

userdata

style Pointer

Return Value

None

Examples

local style = lvgl.style_create()
-- ...
-- ...
-- lvgl.style_delete(style)

lvgl.style_list_delete(style)#

Delete style_list, use caution, usually do not perform delete operation

Parameters

Incoming Value Type

Explanation

userdata

style Pointer

Return Value

None

Examples

local style_list = lvgl.style_list_create()
-- ...
-- ...
-- lvgl.style_list_delete(style_list)

lvgl.demo_benchmark()#

lvgl benchmark demo

Parameters

None

Return Value

return value type

explanation

nil

No return value

Examples

lvgl.init()
lvgl.demo_benchmark()

lvgl.demo_keypad_encoder()#

lvgl keypad_encoder demo

Parameters

None

Return Value

return value type

explanation

nil

No return value

Examples

lvgl.init()
lvgl.demo_keypad_encoder()

lvgl.demo_music()#

lvgl music demo

Parameters

None

Return Value

return value type

explanation

nil

No return value

Examples

lvgl.init()
lvgl.demo_music()

lvgl.demo_printer()#

lvgl printer demo

Parameters

None

Return Value

return value type

explanation

nil

No return value

Examples

lvgl.init()
lvgl.demo_printer()

lvgl.demo_stress()#

lvgl stress demo

Parameters

None

Return Value

return value type

explanation

nil

No return value

Examples

lvgl.init()
lvgl.demo_stress()

lvgl.demo_widgets()#

lvgl widgets demo

Parameters

None

Return Value

return value type

explanation

nil

No return value

Examples

lvgl.init()
lvgl.demo_widgets()

lvgl.indev_drv_register(tp, dtp)#

Register Input Device Driver

Parameters

Incoming Value Type

Explanation

string

Device type, currently supports “pointer”, pointer class/touch class, “keyboard”, keyboard type

string

Device model, currently supports “emulator”, emulator type

Return Value

return value type

explanation

bool

Returns true on success, otherwise false

Examples

lvgl.indev_drv_register("pointer", "emulator")

lvgl.indev_point_emulator_update(x, y, state)#

Update coordinate data for analog input devices

Parameters

Incoming Value Type

Explanation

int

x Coordinates, with the upper left corner as 0 and the lower right corner as the maximum value

int

y Coordinates, with the upper left corner as 0 and the lower right corner as the maximum value

int

State, 0 is released, 1 is pressed

Return Value

return value type

explanation

nil

No return value

Examples

-- Simulate clicks on the screen, simulate long and short presses through the timeout
sys.taskInit(function(x, y, timeout)
    lvgl.indev_point_emulator_update(x, y, 1)
    sys.wait(timeout)
    lvgl.indev_point_emulator_update(x, y, 0)
end, 240, 120, 50)

lvgl.indev_kb_update(key)#

Update key values for keyboard input devices

Parameters

Incoming Value Type

Explanation

int

Key value, default 0, key up

Return Value

return value type

explanation

nil

No return value

Examples

None


lvgl.gif_create(parent, path)#

create gif component

Parameters

Incoming Value Type

Explanation

userdata

The parent component, which can be nil, but typically will not be nil

string

File Path

Return Value

return value type

explanation

userdata

The component pointer. If it fails, nil is returned. We recommend that you check

Examples

local gif = lvgl.gif_create(scr, "S/emtry.gif")
if gif then
    log.info("gif", "create ok")
end

lvgl.gif_restart(gif)#

Replay the gif component

Parameters

Incoming Value Type

Explanation

userdata

gif Component support, returned by the gif_create method

Return Value

return value type

explanation

nil

No return value

Examples

local gif = lvgl.gif_create(scr, "S/emtry.gif")
if gif then
    log.info("gif", "create ok")
end