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

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

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

LittleVgl GUI中實現(xiàn)嵌入中文輸入法框架

TopSemic嵌入式 ? 來源:AET網(wǎng)站 ? 作者:jicheng0622 ? 2022-04-02 09:42 ? 次閱讀

時隔一年多終于又冒泡了,哎,隨著工作越來越忙,自己踏實坐下來寫點東西真是越來越費勁,這篇文章也是準備了好久好久才打算發(fā)表出來(不瞞大家,東西做完好久了,文章憋了一年了,當真“高產(chǎn)”出,咳咳),本來想著好久不見該好好扯點兒閑皮撈點兒閑嗑,結(jié)果兒子跑來旁邊嘮嘮叨叨的把我靈感都整沒了。。。最近國內(nèi)疫情嚴重,還有東航的事件,再回首身邊家人朋友同事,真心感謝靜好的歲月,也感謝負重前行的人,希望疫情早點結(jié)束,待到春花浪漫時,生活處處有生機,不多說了,talk is cheap, let's writing...

LittleVgl作為一款開源免費的嵌入式GUI得到越來越多工程師的厚愛,我們可以看到很多小型HMI項目或者一些開源社區(qū)都在使用它作為GUI的框架,同時也受益于用戶群的不斷擴大以及一些半導體原廠的青睞(通俗點就是說有贊助有錢兒了),LittleVgl本身也在快速的不斷更新迭代,易用的組件和相關(guān)的輔助開發(fā)工具在不斷的增加,而RT1050/1060/1170系列作為一款帶有LCD控制器的平臺,自然成為了LittleVgl最佳的載體之一了。

LittleVgl本身的組件已經(jīng)很豐富了,但是遺憾的是一直沒有加入對中文輸入法Keyboard的支持(看了下它在Github上的Contributor List沒有華人),這讓它在我們國內(nèi)的應用有了一些限制(注意在某組件上顯示中文和真正的中文輸入法是不同的概念),所以本項目旨在解決該問題,即把一個簡單輕量的中文輸入法框架嵌入到LittleVgl并跑在RT1050平臺上,并把它開源開放出來,所以不要小看了我的“公益心”,哈哈。

下面進入正題,首先把測試環(huán)境給出來,方便有興趣有能力的朋友可以自行搭建(當然應一部分偷懶的強烈需求,文章后面我隨附贈了完整的移植好的工程),然后我再一步一步地給出如何移植這套框架到用戶自己的工程里,當然我已經(jīng)把代碼本身做了很多優(yōu)化,盡量減小環(huán)境依賴,力求最少步驟的移植過程,“理論上”來講不太會出現(xiàn)移植后編譯出一堆Error的問題,咳咳。。。下面我們趕緊開整吧:

測試環(huán)境:

SDK版本:SDK_v2.9.1

SDK參考例程:boardsevkbimxrt1050littlevgl_exampleslittlevgl_demo_widgets

LittleVgl版本:v7.4.0

IDE工具:Keil_v5.31

開發(fā)板:MIMXRT1050-EVK + 480*272 RGB LCD屏

軟件說明:

我們先看下這套中文輸入法所需的幾個文件,如下圖所示,.c和.h文件加起來一共7個,其中nxp_logo.c只是我額外加的一個NXP的官方logo圖標轉(zhuǎn)成的C數(shù)組文件供littleVgl調(diào)用顯示,屬于錦上添花的東西,可有可無,真正跟輸入法相關(guān)的是剩下的6個文件,下面我們逐一介紹下這幾個文件的作用:

ac302460-b18b-11ec-aa7f-dac502259ad0.png

1. qwerty_py.c/.h,實際上這兩個文件才是這套全鍵盤拼音中文輸入法的核心框架,實現(xiàn)了對輸入的拼音字母進行索引匹配對應的漢字候選列表,這部分我是移植了如下鏈接中網(wǎng)友分享的代碼,所以這兩個文件我的角色只是一個大自然搬運工,不過說實話我是很感激該網(wǎng)友的無私分享的(這也是我一直推崇開源分享精神的源動力),之前對平時使用的各種輸入法里面的算法原理一直充滿好奇,直到看了這篇文章后才豁然開朗,“So that is what it is!”,讓我獲益匪淺(可能人的學習曲線和知識體系就是這樣一點一滴的積累吧),而且更關(guān)鍵的是,如果讓我繼續(xù)往下開發(fā)諸如拼音聯(lián)想和多漢字輸入等功能的話,我更多關(guān)心的可能只是邏輯搭建的工作量問題,而不是糾結(jié)于Yes or No的問題了,因為咱已經(jīng)了解了其最底層的工作原理了,所以很多復雜的事情,我們?nèi)绻艹榻z剝繭的找到其最底層的本質(zhì)(雖然這真的很難),那很多讓人抓耳撓腮的問題很快就可以理清思路。說到這里我思維又發(fā)散了,呵呵,我想起讓Linus Torvalds等一波老大神們一直頭疼的Linux內(nèi)核維護后繼無人的問題,其實我的個人理解有很大一部分原因是如今的Linux太龐大了以至于幾乎沒有后輩的人對Linux的理解能趕上這些老輩大神,而這些老輩大神的最大優(yōu)勢是他們創(chuàng)建了Linux最早期的底層框架而且難能可貴的是一直在follow Linux每個版本的歷史。總之,推薦大家看看如下這篇文章吧(實際上主要內(nèi)容也都是代碼),希望能各有所獲;

https://www.amobbs.com/thread-5668320-1-1.html?_dsign=0939dcbd

2. lv_chs_keyboard.c/.c文件,這部分就是我的工作了(咱也不能啥都搬運…,這是體現(xiàn)咱的value的東西不是),我把它當作littleVgl的一個補充組件來寫的,里面的大多數(shù)API參考官方littlevgl的lv_keyboard.c,所謂的文章開頭的嵌入中文輸入法到LittleVgl GUI環(huán)境中實際上就是這兩個文件干的活,即將上面提到qwerty.c/.h實現(xiàn)的拼音輸入法與LittleVgl框架結(jié)合到一塊,起到一個橋梁的作用,所以如果你想把這套中文輸入法嵌入到其他GUI環(huán)境中的話(比如emWin,GUIX,TouchGFX等),那主要的工作就是參考這兩個文件的內(nèi)容了;

3. lv_font_NotoSansCJKsc_Regular.c字體文件,雖然littleVgl官方源碼包里自帶了一個中文字體文件(lvglsrclv_fontlv_font_simsun_16_cjk.c),但是它只包含了1000個左右最常用的字,我實際體驗了下很多我們想用的字都找不到,所以這個時候就需要自己去做一個更全一點的字體庫了。這里面涉及到兩個問題需要考慮,第一是很多我們常見的中文字體是收費的(咱PC機的Microsoft Office套件里的中文字體都是微軟付費買的,所以咱也理解下早年正版Windows為啥辣么貴了,那你問為啥現(xiàn)在便宜了?因為人家現(xiàn)在不靠這個賺錢了唄),第二個是字體轉(zhuǎn)換工具的問題,我們網(wǎng)上找到的字體都是TTF或者OTF格式的,但littleVgl是不認的,需要轉(zhuǎn)換成它支持的字體格式。

對于第一個問題,我網(wǎng)上搜了好久最終選擇了目前用的比較多的Google開源免費的字體,Google真乃金主也,它維護的網(wǎng)站里面字體各種各樣啥都有且是開源免費的,如下鏈接,我選擇的是NotoSansCJKsc字體(最后面的sc表示simplified Chinese,簡體中文),然后它里面又包含了各種字形(regular, bold, light等),可以根據(jù)需要自行選擇,整個包很大(100多MB),拆分成不同字形的就小了(每個14~16MB左右);

https://www.google.com/get/noto/

ac43f6c0-b18b-11ec-aa7f-dac502259ad0.png

對于第二個字體轉(zhuǎn)換工具的問題,LittleVgl官方自帶了一個字體轉(zhuǎn)換工具(online font converter),我個人覺著不太好用(對OTF字體支持的不行),這里推薦阿里大神自己做的一個LittleVgl字體轉(zhuǎn)換工具(LvglFontTool),非常方便好用,且支持加入Awesome圖標;

http://www.lfly.xyz/forum.php?mod=viewthread&tid=24&extra=page%3D1

ac59af2e-b18b-11ec-aa7f-dac502259ad0.png

關(guān)于字體這部分我需要再補充個問題,就是它占用的memory大小,畢竟我們是在嵌入式MCU平臺Flash和RAM的資源是受限的,如下圖所示,該字體文件占用大概1Mbytes的rodata空間(即可尋址的Flash空間,當然該大小可以通過在上圖轉(zhuǎn)換工具中增減一些文字來調(diào) 整),所以在移植本套輸入法之前需要預留足夠的Flash空間,當然對RT平臺來說這部分還好,畢竟其本身就外擴至少幾MB空間的QSPI Flash作為存儲空間的。

ac6e70da-b18b-11ec-aa7f-dac502259ad0.png

4. lv_demo_chineseinput.c/.h文件,這兩個文件屬于應用層實現(xiàn)了,主要關(guān)注該文件中下圖的ta_event_cb函數(shù)(即textarea事件的callback,點擊文本框的輸入時回調(diào)),在里面我們需要按照1,2,3去調(diào)用即可(這三步的API均在lv_chs_keyboard.c/h文件里實現(xiàn));

ac90d9cc-b18b-11ec-aa7f-dac502259ad0.png

至此,這套全鍵盤拼音中文輸入法框架所需的幾個文件就介紹完了,用戶只需要把這幾個文件放到自己的工程設(shè)置好文件搜索路徑,并參考隨本文檔附帶的代碼工程示例,再結(jié)合自己產(chǎn)品的GUI樣式,把這套中文輸入法嵌入到自己應用當中。下面鏈接為本項目github倉庫,覺著不錯的別吝嗇您的小星星,star me!好了,就扯到這兒了,本文首發(fā)ChinaAET,續(xù)發(fā)于CSDN:https://blog.csdn.net/jicheng0622/article/details/123851560和博客園:https://www.cnblogs.com/jicheng0622/p/16078169.html,未完待續(xù)!

https://github.com/jicheng0622/Chinese-Input-Method-Framework-on-MCU-based-LittleVgl-GUI

aca20012-b18b-11ec-aa7f-dac502259ad0.png

審核編輯 :李倩

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

    關(guān)注

    5052

    文章

    18912

    瀏覽量

    300812
  • 開源
    +關(guān)注

    關(guān)注

    3

    文章

    3185

    瀏覽量

    42241
  • GUI
    GUI
    +關(guān)注

    關(guān)注

    3

    文章

    632

    瀏覽量

    39440

原文標題:LittleVgl GUI中實現(xiàn)嵌入中文輸入法框架

文章出處:【微信號:TopSemic,微信公眾號:TopSemic嵌入式】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    瑞芯微RK3566鴻蒙開發(fā)板Android11修改第三方輸入法為默認輸入法

    本文適用于觸覺智能所有支持Android11系統(tǒng)的開發(fā)板修改第三方輸入法為默認輸入法。本次使用的是觸覺智能的Purple Pi OH鴻蒙開源主板,搭載了瑞芯微RK3566芯片,類樹莓派設(shè)計,是Laval官方社區(qū)主薦的一款鴻蒙開發(fā)板。
    的頭像 發(fā)表于 09-24 09:43 ?236次閱讀
    瑞芯微RK3566鴻蒙開發(fā)板Android11修改第三方<b class='flag-5'>輸入法</b>為默認<b class='flag-5'>輸入法</b>

    七大嵌入GUI盤點

    MiniGUI-Standalone三種運行模式運行。它對中文的支持很友好,支持GB2312與BIG5字符集,其他字符集也可以輕松加入。 Qt for MCU 是一個專為嵌入式微控制器(MCU)設(shè)計的圖形框架和工具包,它
    發(fā)表于 09-02 10:58

    【AWTK使用經(jīng)驗】如何添加中文輸入法

    目前需要在AWTK程序中用到中文輸入法,并且要自定義輸入法的聯(lián)想詞,此時需要用到AWStudio添加軟鍵盤和輸入法。下面將介紹如何使用AWStudio在項目中添加
    的頭像 發(fā)表于 06-20 08:25 ?905次閱讀
    【AWTK使用經(jīng)驗】如何添加<b class='flag-5'>中文輸入法</b>

    炬芯科技攜手趣戴科技推動LiteGfx GUI框架嵌入式終端智能設(shè)備上應用

    炬芯科技與上海趣戴科技有限公司(簡稱“趣戴科技”)建立緊密合作關(guān)系,雙方攜手推動LiteGfx GUI框架嵌入式終端智能設(shè)備上應用,降低智能手表設(shè)備GUI界面的開發(fā)門檻。該
    的頭像 發(fā)表于 06-04 16:12 ?906次閱讀

    鴻蒙Ability Kit(程序框架服務(wù))【ExtensionAbility組件】

    ExtensionAbility組件是基于特定場景(例如服務(wù)卡片、輸入法等)提供的應用組件,以便滿足更多的使用場景。
    的頭像 發(fā)表于 06-04 15:54 ?408次閱讀
    鴻蒙Ability Kit(程序<b class='flag-5'>框架</b>服務(wù))【ExtensionAbility組件】

    入門級指紋密碼智能鎖方案簡析以及適用芯片SSD210介紹

    智能門鎖的初級應用。 軟件方面,支持嵌入式Linux系統(tǒng),支持Flythings,LittleVGL,AWTK,TD-UI,QT,mini-GUI等多種GUI圖形開發(fā)界面工具。同時還
    的頭像 發(fā)表于 05-24 17:53 ?1109次閱讀
    入門級指紋密碼智能鎖方案簡析以及適用芯片SSD210介紹

    分享幾個嵌入式中常用的GUI

    一、什么是GUIGUI是圖形用戶界面(GraphicalUserInterface,簡稱GUI,又稱圖形用戶接口)是指采用圖形方式顯示的計算機操作用戶界面。通過GUI
    的頭像 發(fā)表于 04-06 08:09 ?1275次閱讀
    分享幾個<b class='flag-5'>嵌入</b>式中常用的<b class='flag-5'>GUI</b>

    魅族21 Pro啟動Flyme 10.5內(nèi)測,新增AI靈動鍵、AI輔助輸入功能

     在新的AI靈動鍵功能,魅族從手勢導航改成了將AI靈動鍵整合到mBack導航,短按或長按mBack即可呼叫Aicy;而AI輔助輸則把輸入法下方添加了一個新型工具條,用戶可以更快地打開輸入
    的頭像 發(fā)表于 03-04 15:36 ?1189次閱讀

    【飛騰派4G版免費試用】+越品越有味道的體驗

    輸入法 圖6 完成添加 此時,選取右上角的輸入法圖標,將EN輸入法切換到拼音輸入法就可以使用中文輸入法了。 圖7切換
    發(fā)表于 01-13 21:10

    【飛騰派4G版免費試用】ibus中文輸入法安裝

    為例,如下圖: 不知道什么原因,ibus中文輸入法有時會出現(xiàn)bug,可能是系統(tǒng)兼容性的問題,切換到EN再切換回來就恢復正常了。
    發(fā)表于 01-11 22:23

    詳解全志R128 GUI圖形系統(tǒng)—LVGL篇

    LVGL 是一個免費的開源圖形庫,提供了創(chuàng)建嵌入GUI 所需的一切,具有易于使用的圖形元素,美觀的視覺效果和低內(nèi)存占用,采用MIT 許可協(xié)議,可以訪問LittlevGL官網(wǎng)獲取更多資料。
    的頭像 發(fā)表于 12-11 14:49 ?2750次閱讀
    詳解全志R128 <b class='flag-5'>GUI</b>圖形系統(tǒng)—LVGL篇

    詳解全志R128GUI圖形系統(tǒng)——LVGL篇

    使用起來。 lv_g2d_test 應用中有完整的使用示例。 sunximem 在sunximem,實現(xiàn)了管理物理內(nèi)存的封裝,這些函數(shù)都不需要應用調(diào)用,但能加深對整個框架的理解,如下: 接口 說明
    發(fā)表于 12-07 15:43

    誰說單片機不能圖形編程,介紹MCU的TOP 5圖形GUI庫!

    LittlevGL(LVGL) 是一款開源的嵌入式圖形用戶界面(GUI)庫,專為嵌入式系統(tǒng)設(shè)計。LVGL以其輕量級、靈活性和強大的功能而備受開發(fā)者青睞,資源夠的情況下可移植到所有MCU
    的頭像 發(fā)表于 12-07 10:42 ?6940次閱讀
    誰說單片機不能圖形編程,介紹MCU的TOP 5圖形<b class='flag-5'>GUI</b>庫!

    嵌入GUI特訓營』開營啦!是學霸就有獎拿,快來挑戰(zhàn)一下!

    ! ↓↓↓ 點擊這里,馬上入營! 精品課程 在“嵌入GUI特訓營”,通過NXP資深工程師主講的7堂精品技術(shù)課程,你將會—— 了解GUI熱點技術(shù)和開發(fā)技巧 結(jié)識免費的
    的頭像 發(fā)表于 12-01 09:15 ?384次閱讀
    『<b class='flag-5'>嵌入</b>式<b class='flag-5'>GUI</b>特訓營』開營啦!是學霸就有獎拿,快來挑戰(zhàn)一下!

    littlevgl這個GUI怎么樣?相比EMWIN有什么特色?

    littlevgl這個GUI怎么樣?相比EMWIN有什么特色?
    發(fā)表于 10-28 07:03