140 lines
4.1 KiB
ReStructuredText
Raw Normal View History

2025-10-10 16:07:00 +08:00
lvgl和camera图像切换显示工程
=================================
:link_to_translation:`en:[English]`
1. 简介
--------------------
本工程是基于lvgl实现的一个二维码生成应用ui并支持动态切换显示camera图像视频流和lvgl ui。
1.1 规格
,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
* 硬件配置:
* 核心板,**BK7258_QFN88_9X9_V3.2**
* 屏幕转接板,**BEKEN_LCD_V3**
* PSRAM 8M/16M
* 屏幕,**ST7701SN**480 * 854 RGB LCD
1.2 路径
,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
工程路径: ``<bk_avdk源代码路径>/project/lvgl/camera``
2. 框架图
---------------------------------
2.1 软件模块架构图
,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
软件模块架构图见:`图形用户界面 <../../../gui/lvgl/index.html>`_ 中的lvgl framework图。
2.2 代码模块关系图
,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
LVGL的接口都定义在 **lv_vendor.h****lvgl.h** 中。
3. 演示说明
---------------------------------
烧录上电后lvgl ui会自动启动运行LCD默认会显示一个二维码静态页面然后可按照以下方法进行切换测试
- 手机上安装IoT软件安装好后点击该软件进行主页面
- 使用IoT软件点击右上角添加 ``BK7258_DL_04`` 设备,点击开始添加,点击 ``选择Wi-Fi`` 连接可连接互联网的网络并点击下一步;
- 选择自己的蓝牙设备可在上电开机的log中查看也可输入 ``mac`` 命令查看对应的设备MAC地址点击并等待设备连接网络进度至100%
- 手机自动跳转到摄像头预览页面,发送 ``lvcam_open`` 命令可在LCD屏上显示camera图像输入 ``lvcam_close`` 命令可在LCD屏上显示LVGL图像依次进行不断切换显示。
.. note::
该工程可不使用手机IoT软件进行测试直接输入 ``media uvc open 864X480`` 命令打开摄像头,接着再输入对应的切换命令。
4. 代码讲解
---------------------------------
::
void lvcamera_main_init(void)
{
bk_err_t ret;
cli_lvcamera_init();
//只打开LCD显示功能不打开旋转和解码等功能
ret = media_app_lcd_pipeline_disp_open((lcd_open_t *)&lcd_open);
if (ret != BK_OK) {
os_printf("media_app_lcd_pipeline_open failed\r\n");
return;
}
//打开LVGL并启动UI绘制
ret = media_app_lvgl_open((lcd_open_t *)&lcd_open);
if (ret != BK_OK) {
os_printf("media_app_lvgl_draw failed\r\n");
return;
}
}
//切换到camera图像显示
void lvcamera_open(void)
{
os_printf("%s\r\n", __func__);
bk_err_t ret;
if (lvcam_is_open) {
os_printf("lvcam is already open\r\n");
return;
}
if (lcd_jdec_is_first_open) {
//设置旋转90度
media_app_pipline_set_rotate(ROTATE_90);
//打开camera视频流的解码和旋转等功能
ret = media_app_lcd_pipeline_jdec_open();
if (ret != BK_OK) {
os_printf("media_app_lcd_pipeline_jdec_open failed\r\n");
return;
}
lcd_jdec_is_first_open = false;
}
ret = media_app_lvcam_lvgl_close();
if (ret != BK_OK) {
os_printf("media_app_lvgl_close failed\r\n");
return;
}
lvcam_is_open = true;
}
//切换到lvgl ui图像显示
void lvcamera_close(void)
{
os_printf("%s\r\n", __func__);
bk_err_t ret;
if (!lvcam_is_open) {
os_printf("lvcam has not been opened, please input the \"lvcam open \" command\r\n");
return;
}
ret = media_app_lvcam_lvgl_open((lcd_open_t *)&lcd_open);
if (ret != BK_OK) {
os_printf("media_app_lvgl_open failed\r\n");
return;
}
lvcam_is_open = false;
}
.. note::
在输入 ``lvcam open`` 命令后视频流的所有功能都将打开且切换到lvgl显示时也不会关闭camera和lcd变量 ``lvgl_disp_enable`` 主要用来控制显示的流数据。