当前位置: 首页 > news >正文

LVGL开发说明

准备工作

  • LVGL图形化工具:Gui-Guider-Setup-1.8.0-GA.exe
  • LVGL库:lvgl-release-v8.3
  • 屏幕触摸驱动:CST816
  • 屏幕驱动:ST7789
  • 屏幕尺寸:320 * 170

触发事件

  1. 按键的点击事件
    在这里插入图片描述

    添加点击事件
    触摸屏点击对应的按键后就会触发回调函数musicBtnCallback

    void musicBtnCallback(lv_event_t * e)
    {console_infor("musicBtnCallback %s\r\n", (char *)e->user_data);
    }
    lv_obj_add_event_cb(guider_ui.screen_setting_music_btn_7, musicBtnCallback, LV_EVENT_CLICKED, "7");
    
  2. 屏幕手势事件
    注册LV_EVENT_GESTURE事件,当垂直或者水平方向滑动屏幕时就会触发musicGestureCallback回调函数,在回调函数中必须执行lv_indev_wait_release(lv_indev_get_act());不然手势事件很容易与按键的点击事件冲突。本项目使用的触摸芯片为CST816,寄存器IrqCrl(0xFA)设置为cst816_Write_Reg(IrqCrl, IRQ_EN_TOUCH | IRQ_EN_CHANGE);,不使用触摸芯片的手势事件,手势算法有LVGL库底层计算而得。

    void musicGestureCallback(lv_event_t * e)
    {lv_indev_wait_release(lv_indev_get_act());lv_dir_t dir = lv_indev_get_gesture_dir(lv_indev_get_act());console_infor("musicGestureCallback %d %s\r\n", dir, (char *)e->user_data);if (dir == LV_DIR_BOTTOM){}}
    lv_obj_add_event_cb(guider_ui.screen_setting_music, musicGestureCallback, LV_EVENT_GESTURE, "12");
    

    调试打印日志

    00> <INFOR><musicGestureCallback><197>: musicGestureCallback 8 12
    00> <INFOR><musicGestureCallback><197>: musicGestureCallback 2 12
    

分隔符
2025年3月9日

关于UI方面的操作还是在Gui Guider这个工具里实现就好,接下来就详细讲解这个工具的使用,比如控件的按键操作,数值的变化操作,界面的切换,UI操作的逻辑控制等都可以在工具里实现。


http://www.mrgr.cn/news/93644.html

相关文章:

  • 体验开源openeuler openharmony stratovirt模拟器
  • swift -(5) 汇编分析结构体、类的内存布局
  • PAT线上考试 真题/注意细节(甲/乙级)
  • Git系列之git tag和ReleaseMilestone
  • ARMv8寄存器的介绍
  • PAT乙级真题(2014·冬)
  • 【CSS3】基础篇
  • #UVM# 关于 config_db 机制中的直线非直线设置和获取讲解
  • 【Deepseek应用】Zotero+Deepseek 阅读和分析文献(下)
  • linyu-im
  • powershell@宝塔面板批量建站脚本@批量设置@批量部署伪静态设置
  • three.js 在 webGL 添加纹理
  • Linux教学总目录
  • #UVM# 关于 config_db 机制中省略 get 语句的条件
  • 扎实基础:测试工作的基石
  • C++学习之QT基础
  • 【GPT入门】第8课 大语言模型的自洽性
  • 力扣203题:移除链表元素及代码实现分析
  • name ‘bare_metal_version‘ is not mamba_ssm安装
  • Redis|Springboot集成Redis