加入星計(jì)劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴(kuò)散
  • 作品版權(quán)保護(hù)
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長期合作伙伴
立即加入
  • 正文
    • 一、GUI Guider簡介
    • 二、GUI Guider下創(chuàng)建工程
    • 三、GUI Guider里設(shè)計(jì)界面
    • 四、修改MCU工程底層驅(qū)動
  • 推薦器件
  • 相關(guān)推薦
  • 電子產(chǎn)業(yè)圖譜
申請入駐 產(chǎn)業(yè)圖譜

為新LCD屏創(chuàng)建LVGL工程最快的方法是什么?

03/14 12:20
3357
閱讀需 9 分鐘
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點(diǎn)資訊討論

大家好,我是痞子衡,是正經(jīng)搞技術(shù)的痞子。今天痞子衡給大家分享的是使用恩智浦GUI Guider快速創(chuàng)建全新LCD屏示例工程的步驟

在痞子衡舊文? 里,痞子衡介紹了在官方 SDK 裸機(jī)驅(qū)動 elcdif 示例工程基礎(chǔ)上做修改以支持一款全新 LCD 屏的方法,那篇文章主要涉及得是對于 LCD 驅(qū)動 IC 的底層適配改動。今天我們在其基礎(chǔ)之上嘗試用恩智浦 GUI Guider 工具快速創(chuàng)建這款 LCD 屏(深圳柯達(dá)科電子生產(chǎn)的 KD050FWFIA019-C019A)的 LVGL 框架下的示例工程。

一、GUI Guider簡介

LVGL 是一個適用于各種嵌入式平臺和顯示器開源且免費(fèi)的 GUI 框架庫,其第一個版本于 2016 年開源在 github 上。我們知道嵌入式 GUI 應(yīng)用開發(fā)很大的工作量在于 UI 界面的設(shè)計(jì),一個成熟的 GUI 框架通常都自帶配套的 UI 界面編輯工具,但是 LVGL 在 UI 工具方面是比較匱乏的,直到 2022 年初官方才找了家第三方公司合作推出了 SquareLine Studio,并且不幸得是 2024 年 2 月,LVGL 已經(jīng)結(jié)束了和 SquareLine Studio 的合作。

恩智浦作為 LVGL 官方合作伙伴,在 LVGL 的支持上投入了不少精力,正因?yàn)楣俜?UI 工具的匱乏,恩智浦便開發(fā)了 GUI Guider 工具(第一個版本發(fā)布于 2021 年初),借助 GUI Guider 的拖放編輯器可以輕松使能 LVGL 的眾多特性,如小部件、動畫和樣式來創(chuàng)建 GUI,而只需少量代碼或根本無需任何代碼。

    GUI Guider 下載地址: https://www.nxp.com/design/design-center/software/development-software/gui-guider:GUI-GUIDER

GUI Guider 支持了眾多恩智浦 MCU 開發(fā)板以及一些官方指定的 LCD 屏,其生成的示例工程底層代碼也是基于官方 SDK。其軟件版本對應(yīng)關(guān)系可以在工具菜單欄 Help->Release Note 下找到:

二、GUI Guider下創(chuàng)建工程

痞子衡安裝得是最新的 GUI Guider v1.7.0-GA,讓我們打開這個工具創(chuàng)建初始工程,前兩步分別是選 LVGL 版本(v7/v8)以及 MCU 板卡(如果是自制板卡,只需要選對 MCU 型號即可),這里痞子衡選擇了 LVGL v8 以及 MIMXRT1170-EVKB。

第三步選擇模板的時候,有4種選擇,EmptyUI 就是純空界面,Widget 是一些典型的簡單界面模板,Application 是一些復(fù)雜的綜合應(yīng)用界面模板,Local Projects 是導(dǎo)入本地已有的用戶工程界面模板。因?yàn)橹皇亲鲆粋€簡單示例,痞子衡這里選擇了 EmptyUI:

第四步(也是創(chuàng)建工程的最后一步)是設(shè)置 LCD 屏屬性,因?yàn)槲覀冇玫檬切缕?,所以?Panel Type 里需要選擇 Custom,然后手動輸入屏的名稱(會在代碼里生成相應(yīng)宏 DEMO_PANEL_KD050FWFIA019)以及尺寸,最后點(diǎn)擊 Create 按鈕便能生成初始工程。

    Note: 這里設(shè)置的 LCD 屏尺寸(寬高)在工程生成之后無法再更改。

三、GUI Guider里設(shè)計(jì)界面

現(xiàn)在來到了 GUI 設(shè)計(jì)主界面,因?yàn)橹皇呛唵问纠?,我們隨便拖動一個 Label 控件,里面寫入 Hello World 就算設(shè)計(jì)好界面了。界面設(shè)計(jì)完成需要在右上角點(diǎn)擊 Generate Code -> C 以生成相應(yīng)界面構(gòu)建 C 代碼。

四、修改MCU工程底層驅(qū)動

現(xiàn)在讓我們打開創(chuàng)建 GUI 工程指定的文件路徑,找到如下工程目錄,rt1170_qsg_proj.guiguider 便是 GUI 設(shè)計(jì)工程文件,一級目錄下都是跟 GUI 相關(guān)的文件夾(generated 存放工具生成的相關(guān)字庫控件資源文件,custom 里可以自行添加用戶界面響應(yīng)相關(guān)邏輯代碼),sdk 文件夾下則是最終 MCU 工程(MCUX/IAR/MDK/GCC 均支持)。

因?yàn)?GUI Guider 已經(jīng)將所需的源文件全部聚合在這個目錄下,所以我們不用額外再下載任何軟件包。這時候你可以選擇你擅長的 IDE 去做進(jìn)一步開發(fā),痞子衡用 IAR 比較多, 所以便打開了 GUI-Guider-Projectsrt1170_qsg_projsdkiarlvgl_guider_cm7.eww 工程。

    Note:除了 MCUX 的工程可以在導(dǎo)入時另選官方 SDK 版本,其余 IDE 的 SDK 版本均是確定的。如需其它 SDK 版本,需要手動更新 GUI-Guider-Projectsrt1170_qsg_projsdkCore 里文件。

當(dāng)前 GUI Guider 生成的 MCU 工程均是 FreeRTOS 版本,沒有提供裸機(jī)版本。無論工程是否基于 RTOS,這并不影響我們移植全新 LCD 屏的驅(qū)動。按照痞子衡舊文 《在i.MXRT1170上快速點(diǎn)亮一款全新LCD屏的方法與步驟》 里的步驟,將對 elcdif_support.c/h 的改動全部放到 display_support.c/h 里,再添加 fsl_ili9806e.c/h 文件到 lvgl_guider_cm7 工程里便大功告成了。此外由于那篇文章只是點(diǎn)屏,沒有涉及觸摸 IC 的驅(qū)動,所以這里暫時也不用考慮使能觸摸功能,可將 DEMO_InitTouch() 函數(shù)的調(diào)用先注釋掉。

GUI-Guider-Projectsrt1170_qsg_projsdkCoreboarddisplay_support.c
GUI-Guider-Projectsrt1170_qsg_projsdkCoreboarddisplay_support.h
GUI-Guider-Projectsrt1170_qsg_projsdkCorevideofsl_ili9806e.c
GUI-Guider-Projectsrt1170_qsg_projsdkCorevideofsl_ili9806e.h

給板卡供電,連接上新屏 KD050FWFIA019,編譯下載修改后的 lvgl_guider_cm7 工程,這時候就能看到 LVGL 版本的 hello world 正常顯示了:

至此,使用恩智浦GUI Guider快速創(chuàng)建全新LCD屏示例工程的步驟痞子衡便介紹完畢了,掌聲在哪里~~~

推薦器件

更多器件
器件型號 數(shù)量 器件廠商 器件描述 數(shù)據(jù)手冊 ECAD模型 風(fēng)險等級 參考價格 更多信息
ABS10-32.768KHZ-9-T 1 Abracon Corporation CRYSTAL 32.7680KHZ 9PF SMD

ECAD模型

下載ECAD模型
$0.85 查看
FOD420SD 1 onsemi Random Phase Snubberless Triac Driver, 1000-REEL
$2.69 查看
AT27C256R-70PU 1 Atmel Corporation OTP ROM, 32KX8, 70ns, CMOS, PDIP28, 0.600 INCH, GREEN, PLASTIC, MS-011AB, DIP-28

ECAD模型

下載ECAD模型
$2.54 查看
恩智浦

恩智浦

恩智浦半導(dǎo)體創(chuàng)立于2006年,其前身為荷蘭飛利浦公司于1953年成立的半導(dǎo)體事業(yè)部,總部位于荷蘭埃因霍溫。恩智浦2010年在美國納斯達(dá)克上市。恩智浦2010年在美國納斯達(dá)克上市。恩智浦半導(dǎo)體致力于打造全球化解決方案,實(shí)現(xiàn)智慧生活,安全連結(jié)。

恩智浦半導(dǎo)體創(chuàng)立于2006年,其前身為荷蘭飛利浦公司于1953年成立的半導(dǎo)體事業(yè)部,總部位于荷蘭埃因霍溫。恩智浦2010年在美國納斯達(dá)克上市。恩智浦2010年在美國納斯達(dá)克上市。恩智浦半導(dǎo)體致力于打造全球化解決方案,實(shí)現(xiàn)智慧生活,安全連結(jié)。收起

查看更多

相關(guān)推薦

電子產(chǎn)業(yè)圖譜

碩士畢業(yè)于蘇州大學(xué)電子信息學(xué)院,目前就職于恩智浦(NXP)半導(dǎo)體MCU系統(tǒng)部門,擔(dān)任嵌入式系統(tǒng)應(yīng)用工程師。痞子衡會定期分享嵌入式相關(guān)文章