基于Microwindows的嵌入式GUI設(shè)計
引言
嵌入式圖形用戶界面與存儲安全、嵌入式j(luò)ava 虛擬機(jī)并稱為嵌入式系統(tǒng)中的三大關(guān)鍵技術(shù)。在嵌入式應(yīng)用領(lǐng)域,伴隨著硬件技術(shù)的發(fā)展,傳統(tǒng)意義上的人機(jī)交互界面正趨于淡化,取而代之的是具有友好人機(jī)交互支持的嵌入式圖形界面。
嵌入式計算機(jī)系統(tǒng)以其關(guān)鍵部件的高性能、低價格等優(yōu)勢為embedded gui 的發(fā)展奠定了堅實的市場和技術(shù)基礎(chǔ);而基于linux 開放源代碼、遵循不同授權(quán)條款的諸多embedded gui 軟件及其自由開發(fā)者,又大大推進(jìn)了embedded gui 的應(yīng)用進(jìn)程,起到推波助瀾的作用,如microwindows、minigui 及qt/ embedded 等。
嵌入式系統(tǒng)是以應(yīng)用為中心、計算機(jī)技術(shù)為基礎(chǔ)、軟件硬件可裁剪、適應(yīng)應(yīng)用系統(tǒng)對功能、可靠性、成本、體積、功耗嚴(yán)格要求的專用計算機(jī)系統(tǒng)。嵌入式系統(tǒng)的這一定義也就界定了嵌入式系統(tǒng)對embedded gui 的基本要求。這些要求如下: (1) 輕量級、占用系統(tǒng)資源少; (2) 性能高,友好的人機(jī)互動; (3) 可靠性高; (4) 模塊架構(gòu),配置靈活,便于移植。
目前,在嵌入式應(yīng)用領(lǐng)域比較成功的embedded gui主要有minigui、microwindows 和qt/ embedded。
minigui 和microwindows 都是自由軟件,只是前者遵循l gpl 條款,后者遵循mpl 條款。這兩個系統(tǒng)的技術(shù)路線也有所不同。minigui 的策略是首先建立在比較成熟的圖形引擎之上,如svgalib 和libggi ,開發(fā)的重點在窗口系統(tǒng)、圖形接口上。
microwindows 目前的開發(fā)重點則在底層的圖形引擎上,它不需要其它圖形系統(tǒng)的支持。在linux 操作系統(tǒng)上,microwindows 也可以充分利用linux 提供的framebuffer機(jī)制來顯示圖形。并且,microwindows 還具有很強(qiáng)的移植性,能夠在大多數(shù)微處理器上運行。
qt/ embedded 由于移植了大量原來基于qt 的xwindows 程序,提供了非常完整的嵌入式gui 解決方案,再加上opera 瀏覽器,可以說是一個成熟的商業(yè)軟件。然而,qt/ embedded 不能運行在非qt 的軟件中,其源代碼也過于龐大。
作為一個開放源代碼項目,microwindows 將現(xiàn)代圖形窗口技術(shù)的一些特性展現(xiàn)給了編程團(tuán)體,而不需要諸如microsof t windows 或x window 這樣占用較大磁盤和ram 空間的高級窗口的支持。它直接面向顯示硬件本身,不需要任何操作系統(tǒng)或其它圖形系統(tǒng)的支持,可以在linux 2. 0 以上的framebuffer 系統(tǒng)上很好地運行。microwindows 本身就被設(shè)計成便于移植、能夠在大多數(shù)硬件和軟件環(huán)境下運行的embedded gui。
microwindows 最新版本0. 9 有如下新特性:
(1) 支持新的nxl ib 項目,nxl ib 對x11 的二進(jìn)制程序可以不加修改地直接在microwindows 里運行,而無需x11 server 支持;
(2) 支持sharp zaurus、tuxscreen、trimedia 及cygnus x11 平臺;
(3) 內(nèi)建標(biāo)準(zhǔn)化校準(zhǔn)(nxcal) 支持,如一個觸摸屏驅(qū)動程序可以支持包含ipaq、zaurus、ads 和tuxscreen 在內(nèi)的大多數(shù)arm 平臺;
(4) 增強(qiáng)了字符支持,包括big5 、gb2312 、euccn、euckr、eucj p 和j isx0213 等;
(5) 大幅提高了x11 屏幕驅(qū)動程序和文本畫圖的速度;
(6) 32 位argb 硬件驅(qū)動支持單色alpha ;
(7) 支持帶有havi 鍵盤映射的l irc 鍵盤;
(8) 從源代碼中為html 和pdf 文檔自動生成支持基于do
總而言之,最新版本的microwindows 在硬件驅(qū)動加速上、在圖形引擎算法上以及代碼質(zhì)量上,都比原先的版本有較大的改進(jìn)。
[!--empirenews.page--]
microwindows 的api
microwindows 采用分層體系結(jié)構(gòu)設(shè)計,提供了豐富的api 支持,支持win32/ wince gdi 和nano-x兩種api 集。
microwindows 體系結(jié)構(gòu)
microwindows 的體系結(jié)構(gòu)由下至上,分別為具體硬件、驅(qū)動層、圖形引擎層和api 層,如圖1 所示。用戶可以根據(jù)具體應(yīng)用需求對不同層的代碼進(jìn)行修改或重寫。
(1) 設(shè)備驅(qū)動程序。
鍵盤驅(qū)動程序主要有兩個,分別是kbd _ tty. c 和kbd _ bios. c 。前者主要用于linux 和el ks 系統(tǒng),而后者主要用于msdos 實模式。
鼠標(biāo)驅(qū)動程序主要有三個:mou_gpm. c ,用于linux 的一個gpm 驅(qū)動; mou _ ser. c ,用于linux 和el ks 系統(tǒng);mou_gpm. c ,主要用于msdos 系統(tǒng)。
屏幕驅(qū)動程序有面向16 位el ks、msdos 實模式的v ga 驅(qū)動( scr_bios. c、vgaplan4. c、memp14. c 、scr_here. c)和面向linux 的framebuffer ( scr_fb. c、fb. c 等) 兩種。這部分驅(qū)動程序最復(fù)雜,在設(shè)計時可以參考scr_fb. c 來設(shè)計自己的屏幕驅(qū)動程序。
(2) 設(shè)備獨立的圖形引擎。
microwindows 的圖形引擎是設(shè)備獨立的。引擎的每一例程都接受screendevice 結(jié)構(gòu)的指針( psd) 來作為第一個參數(shù)。psd 說明了底層的顯示細(xì)節(jié),如屏幕大小的x 、y 值,屏幕顏色ncolors ,以及諸如打開、關(guān)閉、畫線等函數(shù)指針。
microwindows 的api
microwindows 提供兩個應(yīng)用程序接口:一是win32 接口,這種api 不是很成熟;二是nano-x ,這種api 比較好,結(jié)構(gòu)上清晰,功能上也完全。
在microwindows 上的api 接口函數(shù)的基本模型都是用來初始化屏幕、鍵盤和鼠標(biāo)的驅(qū)動程序,然后一直等待select () 消息循環(huán)。當(dāng)事件發(fā)生時,這條信息將送到用戶程序。如果是用戶請求圖形操作,那參數(shù)將被編碼后送到適當(dāng)?shù)膅dxxx 核心程序上。與原始圖形操作相對的窗口概念是被該層所控制的,也就是說該層的api 函數(shù)定義了窗口及其對應(yīng)系統(tǒng)的概念。這樣,系統(tǒng)坐標(biāo)就能被轉(zhuǎn)成屏幕上顯示的坐標(biāo),并且可將數(shù)據(jù)傳給gdxxx 核心程序,由它進(jìn)行實際操作。該層亦定義圖形/ 顯示文件,并且會將此信息(包括裁減信息) 送到核心程序上。
microwindows 的api 支持大多數(shù)圖形繪制、裁減、窗口工具條繪制及拖拉窗口等程序。nano-x 最先是由davin bell 為minix 設(shè)計的,它被設(shè)計為c/ s 模式,一般是通過unix domain socket 在客戶與服務(wù)器端進(jìn)行通信的,但沒有實現(xiàn)窗口管理,所以對窗口的處理需要使用系統(tǒng)提供的一個插件集,或者完全由應(yīng)用程序員自已開發(fā)。另外,nano-x 不是消息驅(qū)動的,而是基于x 協(xié)議模式。在這種模式下,驅(qū)動整個系統(tǒng)運行的可以說是請求與事件。
請求就是客戶端為了完成某一動作而對服務(wù)器端所發(fā)出的申請,并且為每一個請求都定義了一個標(biāo)識數(shù)。每個請求的結(jié)構(gòu)都是不同的,但類似如下結(jié)構(gòu):