時(shí)隔一年多終于又冒泡了,哎,隨著工作越來越忙,自己踏實(shí)坐下來寫點(diǎn)東西真是越來越費(fèi)勁,這篇文章也是準(zhǔn)備了好久好久才打算發(fā)表出來(不瞞大家,東西做完好久了,文章憋了一年了,當(dāng)真“高產(chǎn)”出,咳咳),本來想著好久不見該好好扯點(diǎn)兒閑皮撈點(diǎn)兒閑嗑,結(jié)果兒子跑來旁邊嘮嘮叨叨的把我靈感都整沒了。。。最近國(guó)內(nèi)疫情嚴(yán)重,還有東航的事件,再回首身邊家人朋友同事,真心感謝靜好的歲月,也感謝負(fù)重前行的人,希望疫情早點(diǎn)結(jié)束,待到春花浪漫時(shí),生活處處有生機(jī),不多說了,talk is cheap, let's writing...
LittleVgl作為一款開源免費(fèi)的嵌入式GUI得到越來越多工程師的厚愛,我們可以看到很多小型HMI項(xiàng)目或者一些開源社區(qū)都在使用它作為GUI的框架,同時(shí)也受益于用戶群的不斷擴(kuò)大以及一些半導(dǎo)體原廠的青睞(通俗點(diǎn)就是說有贊助有錢兒了),LittleVgl本身也在快速的不斷更新迭代,易用的組件和相關(guān)的輔助開發(fā)工具在不斷的增加,而RT1050/1060/1170系列作為一款帶有LCD控制器的平臺(tái),自然成為了LittleVgl最佳的載體之一了。
LittleVgl本身的組件已經(jīng)很豐富了,但是遺憾的是一直沒有加入對(duì)中文輸入法Keyboard的支持(看了下它在Github上的Contributor List沒有華人),這讓它在我們國(guó)內(nèi)的應(yīng)用有了一些限制(注意在某組件上顯示中文和真正的中文輸入法是不同的概念),所以本項(xiàng)目旨在解決該問題,即把一個(gè)簡(jiǎn)單輕量的中文輸入法框架嵌入到LittleVgl并跑在RT1050平臺(tái)上,并把它開源開放出來,所以不要小看了我的“公益心”,哈哈。
下面進(jìn)入正題,首先把測(cè)試環(huán)境給出來,方便有興趣有能力的朋友可以自行搭建(當(dāng)然應(yīng)一部分偷懶的強(qiáng)烈需求,文章后面我隨附贈(zèng)了完整的移植好的工程),然后我再一步一步地給出如何移植這套框架到用戶自己的工程里,當(dāng)然我已經(jīng)把代碼本身做了很多優(yōu)化,盡量減小環(huán)境依賴,力求最少步驟的移植過程,“理論上”來講不太會(huì)出現(xiàn)移植后編譯出一堆Error的問題,咳咳。。。下面我們趕緊開整吧:
測(cè)試環(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屏
軟件說明:
我們先看下這套中文輸入法所需的幾個(gè)文件,如下圖所示,.c和.h文件加起來一共7個(gè),其中nxp_logo.c只是我額外加的一個(gè)NXP的官方logo圖標(biāo)轉(zhuǎn)成的C數(shù)組文件供littleVgl調(diào)用顯示,屬于錦上添花的東西,可有可無,真正跟輸入法相關(guān)的是剩下的6個(gè)文件,下面我們逐一介紹下這幾個(gè)文件的作用:
1. qwerty_py.c/.h,實(shí)際上這兩個(gè)文件才是這套全鍵盤拼音中文輸入法的核心框架,實(shí)現(xiàn)了對(duì)輸入的拼音字母進(jìn)行索引匹配對(duì)應(yīng)的漢字候選列表,這部分我是移植了如下鏈接中網(wǎng)友分享的代碼,所以這兩個(gè)文件我的角色只是一個(gè)大自然搬運(yùn)工,不過說實(shí)話我是很感激該網(wǎng)友的無私分享的(這也是我一直推崇開源分享精神的源動(dòng)力),之前對(duì)平時(shí)使用的各種輸入法里面的算法原理一直充滿好奇,直到看了這篇文章后才豁然開朗,“So that is what it is!”,讓我獲益匪淺(可能人的學(xué)習(xí)曲線和知識(shí)體系就是這樣一點(diǎn)一滴的積累吧),而且更關(guān)鍵的是,如果讓我繼續(xù)往下開發(fā)諸如拼音聯(lián)想和多漢字輸入等功能的話,我更多關(guān)心的可能只是邏輯搭建的工作量問題,而不是糾結(jié)于Yes or No的問題了,因?yàn)樵垡呀?jīng)了解了其最底層的工作原理了,所以很多復(fù)雜的事情,我們?nèi)绻艹榻z剝繭的找到其最底層的本質(zhì)(雖然這真的很難),那很多讓人抓耳撓腮的問題很快就可以理清思路。說到這里我思維又發(fā)散了,呵呵,我想起讓Linus Torvalds等一波老大神們一直頭疼的Linux內(nèi)核維護(hù)后繼無人的問題,其實(shí)我的個(gè)人理解有很大一部分原因是如今的Linux太龐大了以至于幾乎沒有后輩的人對(duì)Linux的理解能趕上這些老輩大神,而這些老輩大神的最大優(yōu)勢(shì)是他們創(chuàng)建了Linux最早期的底層框架而且難能可貴的是一直在follow Linux每個(gè)版本的歷史??傊?a href="http://www.1cnz.cn/v/" target="_blank">推薦大家看看如下這篇文章吧(實(shí)際上主要內(nèi)容也都是代碼),希望能各有所獲;
https://www.amobbs.com/thread-5668320-1-1.html?_dsign=0939dcbd
2. lv_chs_keyboard.c/.c文件,這部分就是我的工作了(咱也不能啥都搬運(yùn)…,這是體現(xiàn)咱的value的東西不是),我把它當(dāng)作littleVgl的一個(gè)補(bǔ)充組件來寫的,里面的大多數(shù)API參考官方littlevgl的lv_keyboard.c,所謂的文章開頭的嵌入中文輸入法到LittleVgl GUI環(huán)境中實(shí)際上就是這兩個(gè)文件干的活,即將上面提到qwerty.c/.h實(shí)現(xiàn)的拼音輸入法與LittleVgl框架結(jié)合到一塊,起到一個(gè)橋梁的作用,所以如果你想把這套中文輸入法嵌入到其他GUI環(huán)境中的話(比如emWin,GUIX,TouchGFX等),那主要的工作就是參考這兩個(gè)文件的內(nèi)容了;
3. lv_font_NotoSansCJKsc_Regular.c字體文件,雖然littleVgl官方源碼包里自帶了一個(gè)中文字體文件(lvglsrclv_fontlv_font_simsun_16_cjk.c),但是它只包含了1000個(gè)左右最常用的字,我實(shí)際體驗(yàn)了下很多我們想用的字都找不到,所以這個(gè)時(shí)候就需要自己去做一個(gè)更全一點(diǎn)的字體庫(kù)了。這里面涉及到兩個(gè)問題需要考慮,第一是很多我們常見的中文字體是收費(fèi)的(咱PC機(jī)的Microsoft Office套件里的中文字體都是微軟付費(fèi)買的,所以咱也理解下早年正版Windows為啥辣么貴了,那你問為啥現(xiàn)在便宜了?因?yàn)槿思椰F(xiàn)在不靠這個(gè)賺錢了唄),第二個(gè)是字體轉(zhuǎn)換工具的問題,我們網(wǎng)上找到的字體都是TTF或者OTF格式的,但littleVgl是不認(rèn)的,需要轉(zhuǎn)換成它支持的字體格式。
對(duì)于第一個(gè)問題,我網(wǎng)上搜了好久最終選擇了目前用的比較多的Google開源免費(fèi)的字體,Google真乃金主也,它維護(hù)的網(wǎng)站里面字體各種各樣啥都有且是開源免費(fèi)的,如下鏈接,我選擇的是NotoSansCJKsc字體(最后面的sc表示simplified Chinese,簡(jiǎn)體中文),然后它里面又包含了各種字形(regular, bold, light等),可以根據(jù)需要自行選擇,整個(gè)包很大(100多MB),拆分成不同字形的就小了(每個(gè)14~16MB左右);
https://www.google.com/get/noto/
對(duì)于第二個(gè)字體轉(zhuǎn)換工具的問題,LittleVgl官方自帶了一個(gè)字體轉(zhuǎn)換工具(online font converter),我個(gè)人覺著不太好用(對(duì)OTF字體支持的不行),這里推薦阿里大神自己做的一個(gè)LittleVgl字體轉(zhuǎn)換工具(LvglFontTool),非常方便好用,且支持加入Awesome圖標(biāo);
http://www.lfly.xyz/forum.php?mod=viewthread&tid=24&extra=page%3D1
關(guān)于字體這部分我需要再補(bǔ)充個(gè)問題,就是它占用的memory大小,畢竟我們是在嵌入式MCU平臺(tái)Flash和RAM的資源是受限的,如下圖所示,該字體文件占用大概1Mbytes的rodata空間(即可尋址的Flash空間,當(dāng)然該大小可以通過在上圖轉(zhuǎn)換工具中增減一些文字來調(diào) 整),所以在移植本套輸入法之前需要預(yù)留足夠的Flash空間,當(dāng)然對(duì)RT平臺(tái)來說這部分還好,畢竟其本身就外擴(kuò)至少幾MB空間的QSPI Flash作為存儲(chǔ)空間的。
4. lv_demo_chineseinput.c/.h文件,這兩個(gè)文件屬于應(yīng)用層實(shí)現(xiàn)了,主要關(guān)注該文件中下圖的ta_event_cb函數(shù)(即textarea事件的callback,點(diǎn)擊文本框的輸入時(shí)回調(diào)),在里面我們需要按照1,2,3去調(diào)用即可(這三步的API均在lv_chs_keyboard.c/h文件里實(shí)現(xiàn));
至此,這套全鍵盤拼音中文輸入法框架所需的幾個(gè)文件就介紹完了,用戶只需要把這幾個(gè)文件放到自己的工程設(shè)置好文件搜索路徑,并參考隨本文檔附帶的代碼工程示例,再結(jié)合自己產(chǎn)品的GUI樣式,把這套中文輸入法嵌入到自己應(yīng)用當(dāng)中。下面鏈接為本項(xiàng)目github倉(cāng)庫(kù),覺著不錯(cuò)的別吝嗇您的小星星,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
審核編輯 :李倩
-
嵌入式
+關(guān)注
關(guān)注
5082文章
19111瀏覽量
304845 -
開源
+關(guān)注
關(guān)注
3文章
3323瀏覽量
42473 -
GUI
+關(guān)注
關(guān)注
3文章
659瀏覽量
39658
原文標(biāo)題:LittleVgl GUI中實(shí)現(xiàn)嵌入中文輸入法框架
文章出處:【微信號(hào):TopSemic,微信公眾號(hào):TopSemic嵌入式】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論