【LVGL-界面切换】

■ LVGL-界面切换

■ 方法一: 删除法

当用户删除一个父对象时,它所有的子对象也会被一并删除。
可以调用 lv_obj_del 函数,直接删除基础对象(父对象) , 然后再创建新的界面。

■ 方法二: 隐蔽法

将界面隐藏起来,当用户使用此方法切换界面时,需要考虑内存溢出的隐患。

void lv_obj_add_flag(lv_obj_t *obj, lv_obj_flag_t f);    //设置一个或多个标志
void lv_obj_clear_flag(lv_obj_t *obj, lv_obj_flag_t f);  //清除一个或多个标志

enum {
	LV_OBJ_FLAG_HIDDEN = (1L << 0), /* 隐藏 */
	LV_OBJ_FLAG_CLICKABLE = (1L << 1),
	LV_OBJ_FLAG_CLICK_FOCUSABLE = (1L << 2),
	LV_OBJ_FLAG_CHECKABLE = (1L << 3),
	LV_OBJ_FLAG_SCROLLABLE = (1L << 4),
	LV_OBJ_FLAG_SCROLL_ELASTIC = (1L << 5),
	LV_OBJ_FLAG_SCROLL_MOMENTUM = (1L << 6),
	LV_OBJ_FLAG_SCROLL_ONE = (1L << 7),
	LV_OBJ_FLAG_SCROLL_CHAIN_HOR = (1L << 8),
	LV_OBJ_FLAG_SCROLL_CHAIN_VER = (1L << 9),
	LV_OBJ_FLAG_SCROLL_CHAIN = (LV_OBJ_FLAG_SCROLL_CHAIN_HOR |
	LV_OBJ_FLAG_SCROLL_CHAIN_VER),
	LV_OBJ_FLAG_SCROLL_ON_FOCUS = (1L << 10),
	LV_OBJ_FLAG_SCROLL_WITH_ARROW = (1L << 11),
	LV_OBJ_FLAG_SNAPPABLE = (1L << 12),
	LV_OBJ_FLAG_PRESS_LOCK = (1L << 13),
	LV_OBJ_FLAG_EVENT_BUBBLE = (1L << 14),
	LV_OBJ_FLAG_GESTURE_BUBBLE = (1L << 15),
	LV_OBJ_FLAG_ADV_HITTEST = (1L << 16),
	LV_OBJ_FLAG_IGNORE_LAYOUT = (1L << 17),
	LV_OBJ_FLAG_FLOATING = (1L << 18),
	LV_OBJ_FLAG_OVERFLOW_VISIBLE = (1L << 19),
	LV_OBJ_FLAG_LAYOUT_1 = (1L << 23),
	LV_OBJ_FLAG_LAYOUT_2 = (1L << 24),
	LV_OBJ_FLAG_WIDGET_1 = (1L << 25),
	LV_OBJ_FLAG_WIDGET_2 = (1L << 26),
	LV_OBJ_FLAG_USER_1 = (1L << 27),
	LV_OBJ_FLAG_USER_2 = (1L << 28),
	LV_OBJ_FLAG_USER_3 = (1L << 29),
	LV_OBJ_FLAG_USER_4 = (1L << 30),
};

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
lvgl实现界面切换的原理是通过创建多个页面(或者说lvgl里的screen)并实现它们之间的互相切换。这样可以将不同的功能和接口分散到不同的页面上,使界面更加优雅,并且适应嵌入式硬件的小屏幕。\[1\]\[2\] 为了方便加载界面内的各个控件,可以将需要与输入设备绑定的控件放到一个结构体中,以便于调用。这个结构体可以参考lvgl的官方示例代码,如lv_demo_keypad_encoder中的结构体定义。\[3\] 在实现页面切换时,可以使用事件处理函数(events_handler)来监听用户的输入或其他触发条件。根据不同的事件,可以通过lvgl提供的API来切换页面,例如使用lv_scr_load函数加载新的页面,或者使用lv_scr_act函数设置当前活动的页面。通过这些API的调用,可以实现页面之间的切换效果。 #### 引用[.reference_title] - *1* *3* [【esp32&lvgl】-2.6 #lvgl-多页面(screen)设定/切换](https://blog.csdn.net/weixin_43326110/article/details/126642410)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [【LVGL】学习笔记--(3)界面切换以及显示优化](https://blog.csdn.net/sinat_33408502/article/details/129242824)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

光芒Shine

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值