當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]0引言嵌入式圖形用戶界面(Graphic User Interface)是嵌入式產(chǎn)品設(shè)計(jì)和開發(fā)的重點(diǎn),隨著嵌入式產(chǎn)品的廣泛應(yīng)用,所實(shí)現(xiàn)的功能也日益強(qiáng)大和復(fù)雜,因此對嵌入式產(chǎn)品的GUI在功能、易用性、穩(wěn)定性等方面提出了更高的要求

0引言

嵌入式圖形用戶界面(Graphic User Interface)是嵌入式產(chǎn)品設(shè)計(jì)和開發(fā)的重點(diǎn),隨著嵌入式產(chǎn)品的廣泛應(yīng)用,所實(shí)現(xiàn)的功能也日益強(qiáng)大和復(fù)雜,因此對嵌入式產(chǎn)品的GUI在功能、易用性、穩(wěn)定性等方面提出了更高的要求。目前的嵌入式GUI多是基于線程實(shí)現(xiàn),在穩(wěn)定性和功能上具有一定的局限性,所以開發(fā)多進(jìn)程的GUI具有重要意義。

1多進(jìn)程圖形用戶界面分析

1.1   多進(jìn)程圖形用戶界面的優(yōu)勢

MiniGUI是由飛漫開發(fā)的基于事件驅(qū)動(dòng)的圖形用戶界面支持系統(tǒng),采用微C/S機(jī)制和分層設(shè)計(jì)模型,利用Unix域套接字實(shí)現(xiàn)客戶應(yīng)用程序和服務(wù)器程序之間的交互。早期的MiniGUI采用基于POSIX線程進(jìn)行消息傳遞和窗口管理的機(jī)制,這種實(shí)現(xiàn)能夠提供最大程度的數(shù)據(jù)共享,實(shí)現(xiàn)多窗口系統(tǒng),但是也造成體系結(jié)構(gòu)上的脆弱,所有的窗口在一個(gè)進(jìn)程或者地址空間中運(yùn)行,一旦某個(gè)線程因?yàn)榉欠ǖ臄?shù)據(jù)訪問而導(dǎo)致崩潰或終止運(yùn)行,整個(gè)圖形用戶界面系統(tǒng)都將受到影響。

在Linux系統(tǒng)中,任務(wù)是以進(jìn)程為單位實(shí)現(xiàn)的。進(jìn)程主要提供兩類虛擬化資源:虛擬地址空間和虛擬CPU。前者保證了進(jìn)程在分配和管理內(nèi)存時(shí)就像機(jī)器上只有這一個(gè)進(jìn)程。類似的,虛擬CPU也使進(jìn)程看上去獨(dú)占了CPU。 Linux系統(tǒng)為進(jìn)程提供了安全的運(yùn)行環(huán)境,保證每個(gè)進(jìn)程的獨(dú)立性,一個(gè)進(jìn)程的崩潰不會(huì)危及其他進(jìn)程。因此在多進(jìn)程模式下,能夠同時(shí)運(yùn)行多個(gè)客戶進(jìn)程,如果某個(gè)進(jìn)程不正常終止,其他的進(jìn)程不會(huì)受到影響,因此實(shí)現(xiàn)多進(jìn)程GUI將極大的提高系統(tǒng)的穩(wěn)定性。

1.2 進(jìn)程間通信方式的選擇

基于多進(jìn)程的GUI能夠?qū)崿F(xiàn)多個(gè)界面窗口的并發(fā)運(yùn)行,通過進(jìn)程間通信(IPC)實(shí)現(xiàn)窗口切換。進(jìn)程間通信有多種形式,如管道、信號(hào)、共享內(nèi)存等。

共享內(nèi)存是由內(nèi)核出于在多個(gè)進(jìn)程間交互信息的目的而保留的一塊內(nèi)存空間,多個(gè)進(jìn)程共享該內(nèi)存空間,如果一個(gè)進(jìn)程更新了其中的數(shù)據(jù),其他的進(jìn)程會(huì)立即看到更新,而且共享內(nèi)存也是速度最快的進(jìn)程間通訊機(jī)制。因此共享內(nèi)存作為進(jìn)程間的通信方式對于多窗口GUI系統(tǒng)的編程實(shí)現(xiàn)非常合適。

1.3 基于微C/S機(jī)制的多進(jìn)程模型

對于在微C/S機(jī)制上運(yùn)行的GUI系統(tǒng),在運(yùn)行過程中只能有一個(gè)服務(wù)器程序,其余的應(yīng)用程序均為客戶程序。各客戶應(yīng)用程序分別運(yùn)行于各自不同的進(jìn)程空間中,并且根據(jù)需要在應(yīng)用程序之間通過進(jìn)程間通信進(jìn)行數(shù)據(jù)交換,完成窗口切換等過程。

MiniGUI為了實(shí)現(xiàn)客戶端和服務(wù)器端之間的通信,定義了一種簡單方便的請求/響應(yīng)結(jié)構(gòu):客戶程序通過制定的結(jié)構(gòu)將請求發(fā)送到服務(wù)器,服務(wù)器處理請求并應(yīng)答。在圖形界面運(yùn)行后,服務(wù)器程序完成Server端連接初始化(ServerStart()),建立服務(wù)器端連接套接字Socket,其文件描述符為listenfd,進(jìn)入到偵聽客戶連接請求狀態(tài),用一個(gè)Idlehandler4Server句柄等待接收客戶端的連接請求消息,在接受到來自于客戶端的連接請求消息后進(jìn)行處理,將客戶應(yīng)用程序加入到當(dāng)前活動(dòng)列表,并將客戶端套接字文件描述符clifd加入到偵聽文件集合中??蛻舳顺绦蛟谕瓿蛇B接初始化后(cli_conn())建立客戶端套接字Socket,并發(fā)送連接請求消息給Server程序,之后采用句柄 IdelHandler4Client偵聽服務(wù)器的返回消息。此后服務(wù)器程序進(jìn)入一個(gè)消息循環(huán)過程,在此循環(huán)過程中繼續(xù)準(zhǔn)備接收已連接的客戶程序的其他消息、新的客戶程序連接請求消息以及由系統(tǒng)產(chǎn)生的鼠標(biāo)、鍵盤事件消息等,并在事件消息處理完成后用函數(shù)Send2Client將需要的消息發(fā)送到相應(yīng)的客戶端應(yīng)用程序。此后客戶端應(yīng)用程序從套接字讀取由服務(wù)器程序處理后返回的消息,并把消息寫到當(dāng)前進(jìn)程的桌面隊(duì)列中,交由本進(jìn)程消息循環(huán)進(jìn)行分發(fā)和處理。在獲得消息處理結(jié)果后用cli_quest()向服務(wù)器端發(fā)送數(shù)據(jù)請求,服務(wù)器端接收數(shù)據(jù)請求后交由handle_request按照請求功能號(hào)的不同調(diào)用不同的服務(wù)例程進(jìn)行處理,完成后發(fā)送一個(gè){HWND_INVALID,0}消息和應(yīng)答數(shù)據(jù),客戶端接收服務(wù)器應(yīng)答消息,至此完成一個(gè)基本的消息循環(huán)通信過程。

基于以上的分析, MiniGUI下的基于微C/S機(jī)制的多進(jìn)程GUI通信模型如圖1所示:

 

相比傳統(tǒng)的嵌入式圖形界面開發(fā),多進(jìn)程圖形用戶界面系統(tǒng)在編程實(shí)現(xiàn)上有較大的復(fù)雜性。圖形用戶界面必須實(shí)現(xiàn)對窗口、層、異步事件、光標(biāo)或者加上觸摸屏的管理,MiniGUI本身的消息機(jī)制的管理與內(nèi)核系統(tǒng)的其他機(jī)制之間的配合等。

2圖形用戶界面的開發(fā)重點(diǎn)

2.1 圖形用戶界面的窗口管理

MiniGUI提供了豐富的圖形構(gòu)件,如窗口、對話框、控件等,能夠?qū)崿F(xiàn)各種應(yīng)用功能。MiniGUI本身是基于事件驅(qū)動(dòng)的圖形用戶界系統(tǒng),所謂事件是指當(dāng)用戶進(jìn)行窗口操作時(shí),如移動(dòng)鼠標(biāo)、單擊鼠標(biāo)、進(jìn)行鍵盤輸入的功能,這些動(dòng)作會(huì)觸發(fā)一個(gè)相應(yīng)的“事件”,并由支持系統(tǒng)收集,以特定方式翻譯為消息。應(yīng)用程序一般包含自己的消息隊(duì)列,以接受系統(tǒng)消息并建立循環(huán),這樣的循環(huán)稱為消息循環(huán)。消息一般由代表消息類型的數(shù)和附加參數(shù)構(gòu)成。

多窗口系統(tǒng)在屏幕上要同時(shí)顯示多個(gè)應(yīng)用程序窗口,程序窗口之間會(huì)有相互重疊關(guān)系。所以GUI系統(tǒng)運(yùn)行后首先要?jiǎng)?chuàng)建一個(gè)根窗口,此窗口在系統(tǒng)啟動(dòng)時(shí)由啟動(dòng)腳本運(yùn)行,是所有其他窗口的依附窗口。其他子窗口由用戶在根窗口內(nèi)點(diǎn)擊相應(yīng)圖標(biāo)產(chǎn)生,并且在子窗口內(nèi)可以繼續(xù)派生出自己的下一級(jí)子窗口,每個(gè)子窗口擁有一個(gè)窗口ID號(hào),以標(biāo)示與上級(jí)窗口的派生關(guān)系,據(jù)此便可以追溯到根窗口,而不至于產(chǎn)生窗口管理的混亂。窗口之間的可以為同級(jí)或者上下級(jí)派生關(guān)系。相互間的邏輯結(jié)構(gòu)如圖2所示:

 

2.2 多任務(wù)優(yōu)先級(jí)分配

由于嵌入式設(shè)備在硬件資源上的局限性,GUI系統(tǒng)對新的任務(wù)請求進(jìn)行運(yùn)行優(yōu)先級(jí)的分配和管理,以避免低運(yùn)行級(jí)任務(wù)造成系統(tǒng)資源的浪費(fèi)。GUI系統(tǒng)優(yōu)先運(yùn)行級(jí)別較高的任務(wù),對新產(chǎn)生的任務(wù)按照預(yù)定方式分配相應(yīng)的運(yùn)行級(jí)別,并與當(dāng)前運(yùn)行的任務(wù)級(jí)別進(jìn)行比較,如果新任務(wù)是最高運(yùn)行級(jí)別的任務(wù),則掛起其他任務(wù)直到新任務(wù)處理結(jié)束;如果是相同運(yùn)行級(jí)別的任務(wù)則把新任務(wù)加入到運(yùn)行隊(duì)列的隊(duì)尾,由內(nèi)核分配CPU時(shí)間片和內(nèi)存資源,與其他的任務(wù)一起進(jìn)行多任務(wù)的并發(fā)處理;如果新任務(wù)運(yùn)行級(jí)別最低則將被放入到系統(tǒng)等待隊(duì)列中,直到其他任務(wù)處理完成再處理新任務(wù)。判斷流程如圖3示:


圖3運(yùn)行級(jí)別判斷流程圖

3嵌入式開發(fā)環(huán)境構(gòu)建

完整的嵌入式開發(fā)環(huán)境由嵌入式目標(biāo)板和宿主機(jī)構(gòu)成,兩者通過網(wǎng)線、計(jì)算機(jī)串口和JTAG連接。用戶程序在宿主機(jī)平臺(tái)上進(jìn)行開發(fā),交叉編譯過的程序燒寫到開發(fā)板中的Flash芯片中。

3.1宿主機(jī)

宿主機(jī)安裝Redhat9.0操作系統(tǒng)、MiniGUI開發(fā)環(huán)境和開發(fā)工具集。工具集包括交叉編譯器gcc、調(diào)試器gdb、C函數(shù)庫glibc和二進(jìn)制工具集binutils。

3.2 目標(biāo)板

1)引導(dǎo)程序(Boot Loader)

是系統(tǒng)復(fù)位后執(zhí)行的一段代碼,首先完成系統(tǒng)硬件的初始化,包括時(shí)鐘設(shè)置、存儲(chǔ)區(qū)影射等,然后跳轉(zhuǎn)到操作系統(tǒng)內(nèi)核的入口,將系統(tǒng)控制權(quán)交給操作系統(tǒng)。 Boot Loader獨(dú)立于操作系統(tǒng)而高度依賴系統(tǒng)硬件,必須自行設(shè)計(jì)。本文采用vivi作為系統(tǒng)的引導(dǎo)程序。其啟動(dòng)分為兩個(gè)階段:第一階段代碼采用匯編語言編寫,主要進(jìn)行與CPU以及存儲(chǔ)設(shè)備密切相關(guān)的工作,并進(jìn)行初始化;第二階段采用C語言編寫,來實(shí)現(xiàn)一般的流程及對板級(jí)的一些驅(qū)動(dòng)支持。

2)Linux內(nèi)核

一般的嵌入式操作系統(tǒng)如uClinux、uC/OS-II通常運(yùn)行在沒有MMU的CPU上,因此在進(jìn)程編程時(shí)具有較大的困難度,所以選擇具有完整 Unix特性的Linux作為操作系統(tǒng)。開發(fā)板采用打過補(bǔ)丁的Linux-2.4.18-rmk7的內(nèi)核,內(nèi)核和補(bǔ)丁可以從ARM的官方網(wǎng)站上下載。在配置內(nèi)核時(shí)去掉無關(guān)的功能以減少內(nèi)核大小,如SCSI、IrDA、手柄等。

3)根文件系統(tǒng)

嵌入式根文件系統(tǒng)(root filesystem)是嵌入式Linux系統(tǒng)的核心部分 ,包含系統(tǒng)使用的軟件和庫,以及所有用來為用戶提供支持架構(gòu)和用戶使用的應(yīng)用軟件,并作為存儲(chǔ)區(qū)讀寫結(jié)果的區(qū)域。

4多進(jìn)程GUI的實(shí)現(xiàn)

基于以上分析,本圖形用戶界面系統(tǒng)采用微C/S機(jī)制,用共享內(nèi)存的進(jìn)程間通信機(jī)制實(shí)現(xiàn)數(shù)據(jù)交換,通過套接字實(shí)現(xiàn)客戶程序與服務(wù)器程序通信。服務(wù)器程序?qū)崿F(xiàn)窗口結(jié)構(gòu)隊(duì)列管理,獲取系統(tǒng)產(chǎn)生的鼠標(biāo)和鍵盤消息并進(jìn)行分發(fā)??蛻暨M(jìn)程從IPC消息隊(duì)列獲取發(fā)往自己的消息,并通過共享內(nèi)存實(shí)現(xiàn)窗口剪切。

經(jīng)過交叉編譯的可執(zhí)行圖形應(yīng)用程序可以通過NFS下載到開發(fā)板,然后通過串口調(diào)試工具進(jìn)行遠(yuǎn)程調(diào)試。在應(yīng)用程序調(diào)試完成后將裁減后的MiniGUI 的函數(shù)庫、配置文件放到為開發(fā)板準(zhǔn)備的根文件系統(tǒng)中,并把主界面的可執(zhí)行文件加入到文件系統(tǒng)的啟動(dòng)腳本,用重新得到的根文件系統(tǒng)生成鏡像文件,然后燒寫到開發(fā)板Flash上,在開發(fā)板啟動(dòng)后即可以進(jìn)入到圖形界面。該系統(tǒng)在嵌入式開發(fā)平臺(tái)上能夠?qū)崿F(xiàn)多窗口運(yùn)行,并且在調(diào)用產(chǎn)生高任務(wù)級(jí)別的任務(wù)時(shí)能夠順利實(shí)現(xiàn)任務(wù)掛起功能。

5結(jié)束語

目前嵌入式產(chǎn)品的在功能實(shí)現(xiàn)上日益復(fù)雜化,簡單的圖形用戶界面系統(tǒng)已經(jīng)很難滿足用戶的實(shí)際需要,比如將來的智能手機(jī)將融入電子地圖、定位導(dǎo)航系統(tǒng)、 PDA、電子字典、多媒體播放等多功能,單一的窗口操作界面顯然不符合用戶要求?;诙?strong>進(jìn)程的GUI系統(tǒng)能夠?qū)崿F(xiàn)多任務(wù)、支持多窗口,并且具有良好的系統(tǒng)穩(wěn)定性,因此必然是嵌入式產(chǎn)品開發(fā)的一個(gè)重點(diǎn),也是未來嵌入式圖形用戶界面的發(fā)展方向。

參考文獻(xiàn)

[1] 周立功等. ARM嵌入式MiniGUI初步與應(yīng)用開發(fā)范例[M].北京:北京航空航天大學(xué)出版社, 2006。

[2] David Mosberger, Stephane Eranian,IA-64 Linux Kernel Design and Implementation[M]。Prince Hall, Jan 30, 2002

[3] MiniGUI編程指南 V2.0 [Z]。http://www.minigui.com

[4] MiniGUI API Reference Manual for V1.3 [Z]. http://www.minigui.com

[5] 鄭樺,劉清,邢航,徐智穹。構(gòu)造嵌入式Linux的文件系統(tǒng)[J]。微計(jì)算機(jī)信息,2004,20(8):49~50

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉