嵌入式GUI分析詳解
隨著手機(jī)、智能手表等便攜式設(shè)備的普及,用戶對(duì)GUI的要求越來越高,嵌入式系統(tǒng)對(duì)GUI的需求也越來越迫切,本文將為大家介紹一個(gè)輕型、占用資源少、高性能、高可靠、便于移植、可配置及美觀的GUI編程框架。
一、什么是嵌入式GUI?
圖形用戶界面(Graphical User Interface,簡稱 GUI,又稱圖形用戶接口)是指采用圖形方式顯示的計(jì)算機(jī)操作用戶界面。嵌入式GUI即在嵌入式設(shè)備上使用顯示屏去顯示操作界面,主要用來與用戶互動(dòng)。
二、市面上常見的GUI
當(dāng)前市面上主流的嵌入式 GUI 主要有:emWin(uCGUI),TouchGFX,Embedded Wizard GUI,以及QT。
TouchGFX 是這兩年才發(fā)布的嵌入式 GUI,以界面華麗,流暢以及強(qiáng)勁的 TouchGFX Designer著稱。美中不足的是 TouchGFX 是要收費(fèi)的。
Embeded Wizard GUI 也是這兩年才發(fā)布的嵌入式 GUI,同樣以華麗,流暢的界面和強(qiáng)勁的GUIBuilder 著稱。獨(dú)創(chuàng) Chora 界面編程語言,讓大家的界面編程極其簡單,GUIBuilder 上面含有非常多的控件,皮膚和主題供用戶選擇,且支持調(diào)試。 美中不足的是 Embeded Wizard GUI 也是要收費(fèi)的。
emWin 屬于老牌的嵌入式 GUI 了,有著十幾年的歷史,軟件架構(gòu)和功能比較成熟了。但是做出來比較炫的效果非常麻煩,且不支持較為復(fù)雜的控件。
QT是是一個(gè)1991年由Qt Company開發(fā)的跨平臺(tái)C++圖形用戶界面應(yīng)用程序開發(fā)框架。目前使用Linux操作系統(tǒng)的GUI設(shè)計(jì)大多數(shù)是基于QT開發(fā)的。
以下是各種GUI對(duì)比表:
三、AWTK使UI像iPhone一樣
AWTK是ZLG集團(tuán)旗下致遠(yuǎn)電子開源的GUI引擎,其寓意有兩方面:
AWorks Toolkit:AWorks平臺(tái)內(nèi)置GUI
Toolkit AnyWhere:為嵌入式、手機(jī)和PC打造的通用GUI
AWUI-js為用戶提供分離界面設(shè)計(jì)和邏輯的框架,AWStudio提供嵌入式組態(tài)軟件和云組態(tài)開發(fā)環(huán)境。美工可以直接在AWStudio組態(tài)軟件中進(jìn)行精美的界面設(shè)計(jì),讓研發(fā)工程師專注于控制邏輯的應(yīng)用程序。
AWTK的主要特點(diǎn):
具有Qt的跨平臺(tái)
支持AWorks嵌入式低端、中端和高端各個(gè)平臺(tái)開發(fā);
支持Linux桌面軟件開發(fā);
支持MacOS桌面軟件開發(fā);
支持Windows桌面軟件開發(fā)
支持Web App開發(fā);
具有emWin的小巧高效
AWTK的小并非真的小,而是它可以很小。這主要得益于:
靈活的架構(gòu)
通常魚和熊掌不兼得,功能強(qiáng)大和代碼體積相互矛盾,AWTK要在嵌入式的低端,中端和高端平臺(tái)上運(yùn)行,要在Android/iOS上運(yùn)行,要在PC甚至Web上運(yùn)行,光靠小是不行的,靈活的架構(gòu)才能 讓它可小可大。
高效的數(shù)據(jù)格式
AWTK的主題數(shù)據(jù)和界面描述數(shù)據(jù),在開 發(fā)時(shí)使用XML格式,運(yùn)行時(shí)則編譯成二進(jìn)制的常量,故無需解析和內(nèi)存分配。圖片和字體也可以預(yù)先解碼并編譯成常量,運(yùn)行時(shí)直接從FLASH讀取,無需解碼和內(nèi)存分配。所以 AWTK在內(nèi)存很小的平臺(tái)仍然可以正常運(yùn)行。
保守的設(shè)計(jì)。
由儉到奢易,由奢到儉難。在設(shè)計(jì)控件時(shí)盡量保守,降低對(duì)底層硬件的要求。AWTK可以在低端嵌入式平臺(tái)上運(yùn)行。 這些平臺(tái)典型的配置是32K RAM,512K Flash和低于100M主頻。
快
AWTK的快主要得益于:
硬件加速
AWTK抽象了硬件加速接口,目前支持 STM32的G2D、NXP的PXP和GPU(OpenGL/OpenGLES),充分挖掘硬件的性能。
緩存繪制
播窗口動(dòng)畫前,預(yù)先繪制窗口到緩存,播放動(dòng)畫(平移/彈出動(dòng)畫)時(shí)只是純粹內(nèi)存拷貝,運(yùn)行效率到達(dá)極致。
高效的數(shù)據(jù)格式
主題數(shù)據(jù)和UI數(shù)據(jù)以高效的二進(jìn)制格式存儲(chǔ),使用時(shí)無需解析和內(nèi)存分配,創(chuàng)建窗口可在瞬間完成。
臟矩形算法
啟用臟矩形算法,每次只繪制變化的部分,提高運(yùn)行效率并降低功耗。
在IM287A的Linux系統(tǒng)上,Qt打開一個(gè)窗口需要3秒以上,AWTK則瞬間以超過40FPS的動(dòng)畫打開窗口(如果使用3FB,可以輕松達(dá)到60FPS)。
具有TouchGfx/Embedded Wizard的酷炫
支持現(xiàn)代GUI常見特性:
窗口動(dòng)畫
支持平移、彈出、縮放和淡入淡出等動(dòng)畫。
控件動(dòng)畫
支持移動(dòng)、縮放、翻轉(zhuǎn)、值變化和淡入淡出等動(dòng)畫。
動(dòng)畫支持緩動(dòng)作效果
支持加速、減速和彈跳等數(shù)十種效果,亦可以自定義想要的效果。
支持滑動(dòng)
ListView/SlideView/Selector/Switch等控件支持滑動(dòng)效果。
支持游戲引擎常見功能
幀動(dòng)畫、骨骼動(dòng)畫(TODO)和粒子效果(TODO)。
主題支持全局和窗口兩種方式
輕松定制控件的外觀效果,而無需要改變系統(tǒng)的主題。
分離界面描述文件
開發(fā)時(shí)采用XML格式描述,運(yùn)行時(shí)編譯成二進(jìn)制格式。分離界面方便了開 發(fā),而又無運(yùn)行時(shí)的開銷。
穩(wěn)定
通過良好的架構(gòu)設(shè)計(jì)和編程風(fēng)格、單元測(cè)試、動(dòng)態(tài)(valgrind)檢查和Code Review保證其運(yùn)行的穩(wěn)定性。
完全開源,商用免費(fèi)
開放全部源碼;
商業(yè)應(yīng)用免費(fèi);
沒有陰謀,放心使用,不要想多了。但我們會(huì)為ZLG集團(tuán)的客戶提供更好的服務(wù)和支持。
AWTK,使UI像iPhone一樣!