RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

LVGL適配到OpenMV工程的實(shí)現(xiàn)方法

RTThread物聯(lián)網(wǎng)操作系統(tǒng) ? 來源:RTThread物聯(lián)網(wǎng)操作系統(tǒng) ? 2024-08-09 16:51 ? 次閱讀

板級(jí)適配

得益于官方團(tuán)隊(duì)對(duì) RA8D1-Vision Board 的 SDK 貼心地維護(hù),對(duì)于板級(jí)配置文件 configuration.xml 板載的攝像頭、SDRAM、LCD、TOUCH 等眾多外設(shè)都已經(jīng)配置好了

1ec9f756-4e62-11ef-b8af-92fbcf53809c.png

LVGL 適配到 OpenMV 工程

menuconfig 配置

LVGL 配置

在 SDK 中的 openmv 工程的基礎(chǔ)上進(jìn)行修改,添加 LVGL V8 的 packages 包,使用 scons --menuconfig 命令進(jìn)入配置窗口,直接鍵入 / 來查找 PKG_USING_LVGL 這個(gè)宏

1ef3510a-4e62-11ef-b8af-92fbcf53809c.png

然后按 1 跳轉(zhuǎn)到 LVGL 的設(shè)置界面,修改版本為 V8.3.5 版本,因?yàn)橹笫褂?GUI Guider 設(shè)計(jì)界面,我用的 GUI Guider 的 LVGL 版本是 V8.3.5,當(dāng)然也可以用別的版本,porting 的代碼可能有些許不一樣

1f0329b8-4e62-11ef-b8af-92fbcf53809c.png

還需要在 > Hardware Drivers Config > On-chip Peripheral Drivers 中使能 LVGL for LCD

1f188baa-4e62-11ef-b8af-92fbcf53809c.png

觸摸配置

在官方 SDK 的 openmv 例程中觸摸是沒有被使能的,這里需要使能一下,在 > RT-Thread online packages > peripheral libraries and drivers > touch drivers 中使能 cst812t 的驅(qū)動(dòng)

1f41ac92-4e62-11ef-b8af-92fbcf53809c.png

然后在 > RT-Thread Components > Device Drivers 中使能觸摸中斷管腳的驅(qū)動(dòng)

1f6ac2bc-4e62-11ef-b8af-92fbcf53809c.png

最后把 packages 包下載下來

1f8aec36-4e62-11ef-b8af-92fbcf53809c.png

porting 配置

這時(shí) lvgl 的完整代碼已經(jīng)自動(dòng)添加到編譯環(huán)境中,下一步就是在 board 文件夾中適配 porting,和之前的文章類似,依然是 lv_conf.h、lv_port_disp.c、lv_port_indev.c 這些文件,這里就不再贅述,直接上代碼

lv_port_disp.c 和之前文章的代碼不太一樣,修改成了全屏刷新的方式

lv_port_disp.c

1f98b7bc-4e62-11ef-b8af-92fbcf53809c.png1fa73ef4-4e62-11ef-b8af-92fbcf53809c.png

lv_port_indev.c

1fbe6f98-4e62-11ef-b8af-92fbcf53809c.png1fd8737a-4e62-11ef-b8af-92fbcf53809c.png20350324-4e62-11ef-b8af-92fbcf53809c.png

lv_conf.h

20585b12-4e62-11ef-b8af-92fbcf53809c.png207ef36c-4e62-11ef-b8af-92fbcf53809c.png

demo 測試

適配好了 LVGL,下面運(yùn)行個(gè) demo 試一下,在 LVGL 的設(shè)置中,將 Enable built-in demos 使能

1f0329b8-4e62-11ef-b8af-92fbcf53809c.png

board/Kconfig 中關(guān)于 LVGL 的配置是 V9 版本的,所以需要改一下

209efa40-4e62-11ef-b8af-92fbcf53809c.png

修改為

20b3f670-4e62-11ef-b8af-92fbcf53809c.png

然后使能 widgets 的 demo

20c79e0a-4e62-11ef-b8af-92fbcf53809c.png

在 hal_entry.c 中添加代碼,lv_user_gui_init 會(huì)自動(dòng)被調(diào)用

20eacace-4e62-11ef-b8af-92fbcf53809c.png

Overflow修改

Surprise,此時(shí),最關(guān)鍵的一步來了,這個(gè)時(shí)候直接編譯的話,會(huì) overflow,region `FLASH’ overflowed by 165240 bytes,足足超了100多KB的Flash,這就需要縮減一些配置了

2107023e-4e62-11ef-b8af-92fbcf53809c.png

因?yàn)殚_發(fā)板上的攝像頭是 OV5640,所以把其他的攝像頭驅(qū)動(dòng)都刪掉

1f41ac92-4e62-11ef-b8af-92fbcf53809c.png

將 openmv 的 buffer 從默認(rèn)的 512000 改成 384000,或者改到 256000

21396ecc-4e62-11ef-b8af-92fbcf53809c.png

編譯燒錄到開發(fā)板,可以看到 openmv 運(yùn)行 hello world 例程的時(shí)候同時(shí)運(yùn)行著 LVGL V8 的 widgets 的 demo

2147c6c0-4e62-11ef-b8af-92fbcf53809c.png

觸摸也可以正常使用

21720f66-4e62-11ef-b8af-92fbcf53809c.png

至此,實(shí)現(xiàn)了 openmv 和 LVGL 的共存,實(shí)現(xiàn)了同時(shí)運(yùn)行,當(dāng)然這還不夠,下面開始介紹 GUI guider 設(shè)計(jì)界面和如何在 openmv IDE 上使用 micropython 調(diào)用 LVGL

界面設(shè)計(jì)

GUI Guider

使用 GUI Guider 來進(jìn)行 LVGL 的拖拽式設(shè)計(jì)一個(gè)簡單界面,左邊用來顯示攝像頭內(nèi)容,右邊用來顯示識(shí)別結(jié)果和 logo

219dc110-4e62-11ef-b8af-92fbcf53809c.png

生成代碼后添加到工程當(dāng)中,然后在 custom 和 generated 文件夾中添加兩個(gè) SConscript 文件,內(nèi)容如下

21c762c2-4e62-11ef-b8af-92fbcf53809c.png21e0c5aa-4e62-11ef-b8af-92fbcf53809c.png

目錄樹如下

21fdfada-4e62-11ef-b8af-92fbcf53809c.png

然后把剛剛的 demo 代碼修改為如下內(nèi)容,載入 GUI Guider 生成的界面

220fbf68-4e62-11ef-b8af-92fbcf53809c.png

編譯燒錄到開發(fā)板,可以看到剛剛設(shè)計(jì)的這個(gè)界面,左邊的因?yàn)槭?canvas 控件,為了節(jié)省 RAM 空間,把生成的代碼刪除了一部分,所以是透明的

22201c82-4e62-11ef-b8af-92fbcf53809c.png

效果如下

2235f246-4e62-11ef-b8af-92fbcf53809c.png

LVGL 和 GUI Guider 界面完成,下面就開始接入到 mpy 了

添加 mpy 自定義庫

解釋型語言本質(zhì)上都是詞法解析、解釋執(zhí)行,或者直接點(diǎn)講就是腳本,mpy 就屬于解釋型語言,添加一個(gè)自定義的庫和方法也是十分容易的,在 mpy 的模塊和方法的定義中,大量使用了宏的方式來對(duì) C API 進(jìn)行添加,當(dāng)然這些宏的種類也有很多

添加模塊與方法

模塊的添加

模塊的定義程序范式如下,需要定義一個(gè)表放入模塊的名字,然后使用 MP_DEFINE_CONST_DICT 宏來定義一個(gè)字典,然后定義一個(gè) mp_obj_module_t 變量

2274ea00-4e62-11ef-b8af-92fbcf53809c.png

此時(shí)僅僅是定義了一個(gè)模塊,并沒有加入到 mpy 中,下一步 打開 packages/micropython-v1.13.0/port/mpconfigport.h 這個(gè)文件添加三行代碼

2293ad3c-4e62-11ef-b8af-92fbcf53809c.png

然后添加到 MICROPY_PORT_BUILTIN_MODULES 這個(gè)宏中,就會(huì)參與到編譯當(dāng)中了

22aef826-4e62-11ef-b8af-92fbcf53809c.png

一般型方法

RT-Thread 也提供了一個(gè)生成器,倉庫地址:https://github.com/SummerGift/RT-MicroPython-Generator,或者點(diǎn)開即用可以訪問我的網(wǎng)站上面放的https://docs.pomin.top/codetools/RT-MicroPython-Generator

使用這個(gè)生成器,傳入參數(shù)設(shè)置為 1 的時(shí)候,生成代碼如下,使用的宏是 MP_DEFINE_CONST_FUN_OBJ_1,傳入一個(gè)泛型指針 arg_1_obj,使用 mp_obj_is_true 來獲取布爾類型的傳入?yún)?shù)

mpy 對(duì)于參數(shù)使用泛型指針的 typedef 類型 mp_obj_t 來傳參,然后使用一些 C 函數(shù)來獲取對(duì)應(yīng)的類型以及值,例如 mp_obj_get_int、py_image_cobj 等 C 函數(shù)來獲取整數(shù)值、圖像指針等

22d2c80a-4e62-11ef-b8af-92fbcf53809c.png

main 型方法

以此類推也有 MP_DEFINE_CONST_FUN_OBJ_0、MP_DEFINE_CONST_FUN_OBJ_2、MP_DEFINE_CONST_FUN_OBJ_3,但是參數(shù)過多的時(shí)候就不適合這樣定義了,因?yàn)樵?ARM 中需要控制參數(shù)的數(shù)量,這時(shí)就引出了 main 形式的定義宏,類似與 main 函數(shù)的 argc 和 argv,輸入?yún)?shù)有 n_args 和泛型指針的指針 args

22ecc14c-4e62-11ef-b8af-92fbcf53809c.png

添加一個(gè) log 方法

QSTR的生成

QSTR 宏定義也可以用前文的生成器來生成

QSTR 的內(nèi)容存放在 packages/micropython-v1.13.0/port/genhdr/qstrdefs.generated.h 中,可以使用 packages/micropython-v1.13.0/port/genhdr/gen_qstr.py 來生成,這里生成了三個(gè)后面需要用到的字符串,其中 guider 是模塊名字,下面兩個(gè)是模塊的方法

22fd6f88-4e62-11ef-b8af-92fbcf53809c.png

添加方法

這里定義一個(gè)名字為 guider 的模塊,帶有一個(gè)名為 lv_print 的方法

230994f2-4e62-11ef-b8af-92fbcf53809c.png

按照前文的方法加入到 built module 宏中然后編譯燒錄到開發(fā)板中

mpy 代碼如下。import guider 模塊然后調(diào)用 lv_print 方法

23203680-4e62-11ef-b8af-92fbcf53809c.png233be146-4e62-11ef-b8af-92fbcf53809c.png

連接到開發(fā)板然后運(yùn)行這個(gè)代碼,可以看到 RTT 的終端打印出了代碼中寫的 log

2356c8d0-4e62-11ef-b8af-92fbcf53809c.png

添加LVGL的自定義方法

定義一個(gè) main 型的方法,代碼如下,實(shí)現(xiàn)傳參一個(gè)圖像類型的參數(shù),獲取了參數(shù)后拷貝到緩沖區(qū),交由 canvas 控件來顯示,并且根據(jù)圖像大小自適應(yīng)調(diào)節(jié)控件大小

23c730ca-4e62-11ef-b8af-92fbcf53809c.png

添加到 guider 模塊中

23d4c8e8-4e62-11ef-b8af-92fbcf53809c.png

此時(shí)就可以實(shí)現(xiàn)傳入攝像頭的圖像到 canvas 控件來顯示了,編譯燒錄到開發(fā)板,然后連接到 openmv IDE 運(yùn)行如下 mpy 代碼

23e2ff94-4e62-11ef-b8af-92fbcf53809c.png

攝像頭,啟動(dòng)!

23f0a536-4e62-11ef-b8af-92fbcf53809c.png

再添加一個(gè)顯示識(shí)別結(jié)果的方法,實(shí)現(xiàn)對(duì)傳入的字符串顯示到 LVGL 界面的 label 控件上

24347522-4e62-11ef-b8af-92fbcf53809c.png

編譯燒錄到開發(fā)板中,在 openmv IDE 中運(yùn)行如下代碼

24488a30-4e62-11ef-b8af-92fbcf53809c.png

將 $ 顯示到了界面的 label 控件上

24673e94-4e62-11ef-b8af-92fbcf53809c.png

運(yùn)行tflite

對(duì)于怎么完成對(duì)于 tflite 模型的訓(xùn)練這里就不再重復(fù)介紹,可以參考這位大佬的文章 https://club.rt-thread.org/ask/article/69ef73018d63deef.html ,跟著一步步操作即可

24a5a8a0-4e62-11ef-b8af-92fbcf53809c.png

下載生成的可以部署到 openmv 的代模型和代碼

24bd3592-4e62-11ef-b8af-92fbcf53809c.png

得到一個(gè)如下文件

24d04c18-4e62-11ef-b8af-92fbcf53809c.png

將 edge impulse 中生成的代碼稍作修改,加入 guider 模塊

24deeb74-4e62-11ef-b8af-92fbcf53809c.png

在 openmv IDE 上運(yùn)行識(shí)別

24f30e42-4e62-11ef-b8af-92fbcf53809c.png252366f0-4e62-11ef-b8af-92fbcf53809c.png

在開發(fā)板屏幕上顯示 LVGL 界面、識(shí)別結(jié)果與攝像頭畫面

255ecb46-4e62-11ef-b8af-92fbcf53809c.png258b17e6-4e62-11ef-b8af-92fbcf53809c.png

最終工程可見 Github 倉庫 https://github.com/POMIN-163/RA8D1-Vision-Board-OpenMV-with-LVGL-V8

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 攝像頭
    +關(guān)注

    關(guān)注

    59

    文章

    4836

    瀏覽量

    95596
  • 命令
    +關(guān)注

    關(guān)注

    5

    文章

    683

    瀏覽量

    22011
  • SDK
    SDK
    +關(guān)注

    關(guān)注

    3

    文章

    1035

    瀏覽量

    45897
  • openMV
    +關(guān)注

    關(guān)注

    3

    文章

    39

    瀏覽量

    9810

原文標(biāo)題:如何優(yōu)雅的在OpenMV上使用LVGL

文章出處:【微信號(hào):RTThread,微信公眾號(hào):RTThread物聯(lián)網(wǎng)操作系統(tǒng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    RT-Thread Studio上移植GUI-Guider-1.4開發(fā)LVGL8.2工程

    創(chuàng)建一個(gè)rttthread工程,選擇出廠帶好LVGL配置的demo,或者自己已經(jīng)搭建好了LVGL環(huán)境的工程。
    的頭像 發(fā)表于 11-03 12:52 ?2221次閱讀
    RT-Thread Studio上移植GUI-Guider-1.4開發(fā)<b class='flag-5'>LVGL</b>8.2<b class='flag-5'>工程</b>

    如何優(yōu)雅的在OpenMV上使用LVGL

    LVGL適配到OpenMV工程menuconfig配置LVGL配置在SDK中的openmv
    的頭像 發(fā)表于 07-31 08:36 ?1048次閱讀
    如何優(yōu)雅的在<b class='flag-5'>OpenMV</b>上使用<b class='flag-5'>LVGL</b>

    如何在openmv實(shí)現(xiàn)圖傳功能?

    Vision board的openmv固件wifi只能實(shí)現(xiàn)連接,一些通信和物聯(lián)網(wǎng)也用不了。如果我要實(shí)現(xiàn)openmv中的圖傳功能該怎么做呢,求助各位大佬
    發(fā)表于 07-09 06:36

    如何實(shí)現(xiàn)openmv和STM32之間的UART通訊?

    我已經(jīng)嘗試過,用OPENMV直接發(fā)送一給串口助手,串口助手可以接受到,用STM32自己的TX給RX寫信息,改變某一引腳的電平,可以實(shí)現(xiàn)(就是STM32的讀沒問題)。但是openmv給STM32送數(shù)據(jù)
    發(fā)表于 07-19 19:36

    OpenMv和STM32如何實(shí)現(xiàn)通信?

    OpenMv和STM32如何實(shí)現(xiàn)通信?
    發(fā)表于 11-17 06:14

    OpenMV簡單實(shí)現(xiàn)物體追蹤

    簡單實(shí)現(xiàn)物體追蹤OpenMV簡介材料準(zhǔn)備OpenMV實(shí)現(xiàn)脫機(jī)運(yùn)行1.將OpenMV與電腦連接2.使用IDE把軟件內(nèi)自帶的代碼燒錄到OpenM
    發(fā)表于 11-30 06:59

    怎么實(shí)現(xiàn)OPENMV與STM32串口通信?

    怎么實(shí)現(xiàn)OPENMV與STM32串口通信?
    發(fā)表于 12-07 06:36

    如何實(shí)現(xiàn)Openmv與stm32之間的通信?

    如何實(shí)現(xiàn)Openmv與stm32之間的通信?
    發(fā)表于 02-18 07:39

    基于OPENMV和STM32的識(shí)別追蹤小車設(shè)計(jì)實(shí)現(xiàn)

    OPENMV和STM32的識(shí)別追蹤小車(詳細(xì)版)實(shí)現(xiàn):通過OPENMV識(shí)別Apriltags標(biāo)簽,STM32驅(qū)動(dòng)小車追蹤標(biāo)簽博主通過一段時(shí)間的學(xué)習(xí),做了這個(gè)比較簡單的以OPENMV為攝
    發(fā)表于 02-25 06:21

    RISC-V SIG成功將Chromium等桌面軟件適配到openEuler RISC-V

    近日,RISC-V SIG 成功將 Chromium 等桌面軟件適配到 openEuler RISC-V,這是繼 openSUSE 之后第二個(gè)跑起來 Chromium 的 RISC-V 發(fā)行版。
    的頭像 發(fā)表于 08-26 14:07 ?2204次閱讀

    LVGL Simulation工程

    最近在玩一個(gè)開源項(xiàng)目,用到ESP32,玩著玩著感覺開源項(xiàng)目的UI太枯燥了,于是了解到了LVGL,網(wǎng)上很多關(guān)于ESP32跑LVGL的現(xiàn)有工程
    的頭像 發(fā)表于 05-11 09:12 ?1123次閱讀
    <b class='flag-5'>LVGL</b> Simulation<b class='flag-5'>工程</b>

    Hi3861移植LVGL教程

    給 Hi3861 適配了硬件 spi ,master 模式下最高 spi 速率可以達(dá)到 40M,用來驅(qū)動(dòng) oled 屏幕。適配過程遇到了一個(gè)芯片bug,困擾了很久,clk 管腳驅(qū)動(dòng)能力差,需要外接一個(gè)上拉電阻才能正常運(yùn)行。適配
    的頭像 發(fā)表于 05-18 09:23 ?2221次閱讀
    Hi3861移植<b class='flag-5'>LVGL</b>教程

    OpenMV初識(shí)

    在嵌入式端進(jìn)行python開發(fā)。OpenMV基于32位,ARM Cortex-M7內(nèi)核的OpenMV-H7, 并結(jié)合各種攝像頭,可以進(jìn)行多種機(jī)器視覺應(yīng)用的實(shí)現(xiàn),比如人臉檢測,物體分類等。
    的頭像 發(fā)表于 06-12 11:23 ?3891次閱讀
    <b class='flag-5'>OpenMV</b>初識(shí)

    基于OpenMV實(shí)現(xiàn)演示與導(dǎo)出

    從原圖到實(shí)現(xiàn),不用寫一行OpenCV代碼,借助OpenMV工具輕松導(dǎo)出流程,可以整合到C++,支持各種上位機(jī)集成,讓你用OpenCV開發(fā)的速度成倍提升。大大降低OpenCV開發(fā)難度,提升開發(fā)效率。
    發(fā)表于 09-01 15:23 ?797次閱讀
    基于<b class='flag-5'>OpenMV</b><b class='flag-5'>實(shí)現(xiàn)</b>演示與導(dǎo)出

    基于Vision Board上的openMV垃圾分類

    通過在Vision Board部署openMV實(shí)現(xiàn)垃圾分類。
    的頭像 發(fā)表于 06-17 10:49 ?632次閱讀
    基于Vision Board上的<b class='flag-5'>openMV</b>垃圾分類
    RM新时代网站-首页