国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

基于高通手機(jī)平臺(tái)漢字顯示解決方案

發(fā)布時(shí)間:2010-9-21 11:07    發(fā)布者:eetech
關(guān)鍵詞: 高通 , 漢字 , 解決方案 , 手機(jī) , 顯示
1 引 言  

高通作為全球領(lǐng)先CDMA手機(jī)平臺(tái)供應(yīng)商,在國(guó)內(nèi)得到廣大手機(jī)設(shè)計(jì)公司和手機(jī)廠商的青睞,其中包括德信無(wú)線、上海精佑、賽龍上海和UT斯達(dá)康等國(guó)內(nèi)許多手機(jī)設(shè)計(jì)公司和手機(jī)廠商。為了支持國(guó)內(nèi)市場(chǎng),漢字顯示是必不可少的,而高通手機(jī)平臺(tái)上沒有直接提供完備的漢字顯示解決方案,本文就這個(gè)熱點(diǎn)論題,通過(guò)對(duì)高通手機(jī)平臺(tái)字符顯示特點(diǎn)進(jìn)行了分析,具體地給出了基于BMP文件格式存儲(chǔ)漢字字庫(kù)的一種漢字顯示方案。

2 高通手機(jī)平臺(tái)Brew字符顯示原理

高通手機(jī)平臺(tái)Brew字符顯示由兩部分構(gòu)成,一部分為上層應(yīng)用提供一個(gè)統(tǒng)一的字符顯示接口部分,另一部分為某一種字符集或字體具體實(shí)現(xiàn)部分,這兩個(gè)部分是通過(guò)虛函數(shù)機(jī)制綁定在一起。在Brew字符顯示接口統(tǒng)一定義如下:

IFONT AddRef():用于引用記數(shù)功能;

IFONT_Release():釋放當(dāng)前應(yīng)用程序字符顯示實(shí)例;

IFONT_QueryInterface():他根據(jù)字符ID檢索當(dāng)前應(yīng)用程序字符顯示實(shí)例;

IFON_DrawText():他用于顯示具體的文本;

IFONT_MeasureText():他用于計(jì)算以象素為單位文本的大小和字符的總數(shù)目;

IFONT_GetFontInfo():他用于檢索字符相關(guān)信息,比如ascent和descent的值。

從上面的顯示接口定義可見,系統(tǒng)的設(shè)計(jì)者將字符顯示接口視為一個(gè)脫離依賴具體字符顯示的轉(zhuǎn)換模塊,而字符具體實(shí)現(xiàn)部分則需要根據(jù)顯示接口每個(gè)接口函數(shù)給出一個(gè)標(biāo)準(zhǔn)實(shí)現(xiàn),功能就是針對(duì)某一種字符實(shí)現(xiàn)文本顯示,計(jì)算文本大小,返回該種字體一些信息等。

例如:高通關(guān)于ASCII字符顯示的參考設(shè)計(jì)中就定義了一組與顯示接口一致的一組函數(shù):



然后通過(guò)指針賦值方式把這組函數(shù)與接口函數(shù)對(duì)應(yīng)部分關(guān)聯(lián)起來(lái),即在函數(shù)AEEVarBitFont_NewFromBBF內(nèi)部通過(guò)指針賦值方式使顯示接口部分與具體實(shí)現(xiàn)部分綁定在一起。

上層應(yīng)用模塊調(diào)用字符顯示模塊的過(guò)程如下:



3 高通手機(jī)平臺(tái)上漢宇字庫(kù)的BMP文件存儲(chǔ)結(jié)構(gòu)的設(shè)計(jì)

在手機(jī)平臺(tái)上漢字顯示可以采用國(guó)標(biāo)碼或Unicode任何一種編碼方案,但為了信息交換方便,大多數(shù)手機(jī)開發(fā)采用Unicode顯示方式,這里以Unicode為例來(lái)說(shuō)明。傳統(tǒng)的漢字存儲(chǔ)結(jié)構(gòu)采用數(shù)組方式,明顯地,字符集這種存儲(chǔ)方式無(wú)法直觀地顯示給用戶和軟件開發(fā)者,用戶和軟件開發(fā)者也很難了解字符集內(nèi)真正包含了那些字符,再者,當(dāng)顯示漢字時(shí),系統(tǒng)需要將漢字字模存儲(chǔ)方式轉(zhuǎn)換為屏幕顯示方式,這將會(huì)增加系統(tǒng)開銷,降低運(yùn)行效率。這里設(shè)計(jì)了用BMP文件格式來(lái)存儲(chǔ)漢字字庫(kù),他保證整個(gè)存儲(chǔ)空間沒有明顯增加的同時(shí),能夠使用戶直觀地了解字符集內(nèi)包含了那些字符,提高系統(tǒng)運(yùn)行效率。

與現(xiàn)有其他的漢字存儲(chǔ)結(jié)構(gòu)和漢字顯示方法相比,該方法具有3個(gè)主要特點(diǎn):

直觀性強(qiáng) 由于采用BMP圖片存儲(chǔ)結(jié)構(gòu)方式,可以瀏覽漢字字符集中包含的漢字;

運(yùn)行效率高 由于采用BMP圖片存儲(chǔ)結(jié)構(gòu)方式,使得單個(gè)字符的字模存儲(chǔ)方式與屏幕顯示方式保持一致,當(dāng)顯示漢字時(shí),不需要把漢字字模存儲(chǔ)方式轉(zhuǎn)換為屏幕顯示方式;

可移植性強(qiáng)、開發(fā)周期較短 對(duì)上層應(yīng)用模塊漢字顯示耦合得更好,由于這種方法盡可能地采用了Brew系統(tǒng)現(xiàn)有的字符顯示參考設(shè)計(jì)和已有的顯示接口機(jī)制。

由于漢字的Unicode編碼范圍為u4E00~u9FA5和uF900~uFA2D,如果不在這個(gè)范圍內(nèi)就不是漢字了。為了討論方便,這里考慮漢字Unicode編碼范圍為u4E00~ugFA5,總計(jì)有20 901個(gè)漢字,他們是連續(xù)編碼的。

16*16漢字字庫(kù)BMP文件格式描述如下:

從上面的存儲(chǔ)結(jié)構(gòu)可知,他實(shí)際就是一幅BMP格式的漢字字庫(kù)圖片,這幅BMP圖片就是漢字字符集的二進(jìn)制表示,他是從BMP圖片格式轉(zhuǎn)換過(guò)來(lái)的。這里每個(gè)字符字模對(duì)應(yīng)BMP圖片中一個(gè)圖片片,字模存儲(chǔ)方式與屏幕顯示方式是一致的。

4 基于BMP文件存儲(chǔ)結(jié)構(gòu)漢字顯示實(shí)現(xiàn)

實(shí)現(xiàn)本地漢字顯示較早的一種方案基于Native UI,他不需依賴Brew顯示接口。目前較多的漢字顯示方案會(huì)涉及到Brew顯示接口,常見漢字顯示解決方案為:

(1) 基于Native UI方案,實(shí)現(xiàn)漢字顯示。完全自己開發(fā)一套點(diǎn)陣存儲(chǔ)、點(diǎn)陣獲取、點(diǎn)陣顯示、漢字顯示函數(shù),使用者使用特定的漢字顯示函數(shù)把漢字顯示出來(lái)。該方法具有最大的靈活性,甚至不理睬Brew任何顯示接口機(jī)制,直接在上層組件里實(shí)現(xiàn),但這種方法使程序可移植性比較差,對(duì)第三方應(yīng)用程序漢字顯示支持也不方便。   

(2) 基于Brew方案,實(shí)現(xiàn)漢字顯示。自己開發(fā)點(diǎn)陣存儲(chǔ)、點(diǎn)陣獲取、點(diǎn)陣顯示,改造Brew的顯示接口函數(shù),使其能判斷漢字碼,一旦判斷出漢字碼,則使用自己開發(fā)的點(diǎn)陣獲取、點(diǎn)陣顯示等把漢字顯示出來(lái)。然后把該自己開發(fā)的顯示函數(shù)綁接到Brew顯示接口上。該方法對(duì)點(diǎn)陣的操作更加靈活,工作量較大,開發(fā)周期較長(zhǎng),這種方法比較適用已有成熟的點(diǎn)陣操作方法開發(fā)者。

這里利用Brew對(duì)BMP文件格式的支持,使用BMP文件格式實(shí)現(xiàn)對(duì)漢字的點(diǎn)陣存儲(chǔ)、點(diǎn)陣獲取、點(diǎn)陣顯示的全過(guò)程,并使用Brew的顯示函數(shù)實(shí)現(xiàn)漢字碼到漢字顯示。這種方法盡可能地使用了Brew系統(tǒng)現(xiàn)有的字符顯示參考設(shè)計(jì)和已有的顯示接口機(jī)制,開發(fā)周期較短,是最根本的解決方法,他使得Brew的其他上層應(yīng)用模塊能很方便實(shí)現(xiàn)漢字顯示。這種方法使程序通用性好,可移植性強(qiáng),支持第三方應(yīng)用程序開發(fā)也較方便等特點(diǎn)。

為了支持第三方軟件廠商集成不同國(guó)家文字顯示,高通手機(jī)平臺(tái)提供一個(gè)綁定顯示接口和對(duì)應(yīng)的實(shí)現(xiàn)部分的接口函數(shù),通過(guò)這個(gè)函數(shù)就可以把各種不同文字類型顯示方式綁定到Brew統(tǒng)一的顯示接口上,軟件廠商只需要根據(jù)具體文字的顯示方式實(shí)現(xiàn)具體的接口函數(shù)即可。這個(gè)接口如下:




各個(gè)參數(shù)介紹如下

IFont**ppif:漢字接口函數(shù);

const uint16*pwGlyphs:漢字碼表;

int cntGlyphs:漢字總數(shù)目;

const CHAR*pbyBitmap:用BMP表示的漢字字庫(kù);

int cbBitmap:用BMP表示的漢字字庫(kù)總的字節(jié)數(shù)目;

int xCHARWid:每個(gè)漢字寬度;

int yCHARHeight:每個(gè)漢字高度;

int yCHARDescent:點(diǎn)陣打點(diǎn)開始位置在baseline之下的偏移;

uint16 wUndefGlyph:未定義的ASCII字符數(shù)目;

int nHalfCHARs:ASCII字符數(shù)目;

UTFONTTYPE FontType:漢字類型。

為了實(shí)現(xiàn)BMP文件格式存儲(chǔ)結(jié)構(gòu)字庫(kù)的漢字顯示方式,主要工作集中于下面兩個(gè)方面:

(1) 定義創(chuàng)建字體實(shí)例接口函數(shù)

在Brew方案中,上層應(yīng)用模塊都是通過(guò)ID創(chuàng)建字體實(shí)例,這里可以按照如下方式定義創(chuàng)建字體接口函數(shù)。



(2) 實(shí)現(xiàn)漢字顯示一組具體的接口函數(shù)

由于Brew方案中已經(jīng)實(shí)現(xiàn)了基于BMP格式對(duì)ASCII碼顯示支持方式,所以顯示接口函數(shù)IFONT_Ad-dRef(),IFONT_Release(),IFONT_QueryInterface的功能已經(jīng)實(shí)現(xiàn),而漢字顯示方式這三個(gè)函數(shù)要實(shí)現(xiàn)的功能與ASCII是一致的,不需要改動(dòng)。函數(shù)IFONT GetFon-tInfo對(duì)于漢字顯示不適用,因?yàn)闈h字的ascent和descent的值為0,這里只要考慮IFONT_DrawText()和IFONTMeasureText()兩個(gè)函數(shù)的實(shí)現(xiàn)問題。

為了實(shí)現(xiàn)IFONT_MeasureText(),在他對(duì)應(yīng)的實(shí)現(xiàn)函數(shù)內(nèi)部增加計(jì)算一個(gè)漢字寬度的相應(yīng)代碼。

為了實(shí)現(xiàn)IFONT_DrawText(),由于Brew提供了基于BMP格式對(duì)ASCII碼顯示支持方式,對(duì)于漢字顯示關(guān)鍵是計(jì)算漢字UNICODE碼與BMP格式的漢字字模的對(duì)應(yīng)關(guān)系。由于漢字的UNICODE碼是連續(xù),在BMP圖片中字模已經(jīng)按照UNICODE碼順序排列,對(duì)于任何漢字只要計(jì)算他與第一個(gè)漢字(4E00)的偏移量,然后根據(jù)偏移量直接拷貝BMP圖片中該字符的圖片片到顯示緩沖區(qū)即可,不需要把單個(gè)字符字模轉(zhuǎn)換為屏幕顯示方式,提高了系統(tǒng)顯示速度。

5 注意事項(xiàng)

在實(shí)際開發(fā)中,手機(jī)軟件開發(fā)商一般以點(diǎn)陣形式從第三方購(gòu)買字庫(kù),為了能夠應(yīng)用第三方字庫(kù)到高通手機(jī)平臺(tái)上需要轉(zhuǎn)換成BMP格式的文件。另一個(gè)要注意的問題是這里把漢字顯示作為單獨(dú)的一個(gè)字符集來(lái)考慮的,在實(shí)際中可以把ASCII,漢字和漢字偏旁部首構(gòu)成一個(gè)字符集來(lái)考慮。只要根據(jù)不同的碼值分別計(jì)算他們各自對(duì)應(yīng)BMP圖形的偏移量即可。

6 結(jié) 語(yǔ)

本文就高通手機(jī)平臺(tái)關(guān)于漢字存儲(chǔ)和漢字顯示方式這一熱門論題進(jìn)行了詳盡討論,論述高通手機(jī)平臺(tái)Brew字符顯示原理、傳統(tǒng)漢字存儲(chǔ)結(jié)構(gòu)的不足和不同漢字顯示方案的特點(diǎn),并在論述這些原理和方案的同時(shí)提出了一種具有通用強(qiáng),移植方便和容易擴(kuò)展的漢字顯示方案,也提出了在實(shí)際應(yīng)用需要注意問題。
本文地址:http://m.qingdxww.cn/thread-28400-1-1.html     【打印本頁(yè)】

本站部分文章為轉(zhuǎn)載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀點(diǎn)和對(duì)其真實(shí)性負(fù)責(zé);文章版權(quán)歸原作者及原出處所有,如涉及作品內(nèi)容、版權(quán)和其它問題,我們將根據(jù)著作權(quán)人的要求,第一時(shí)間更正或刪除。
您需要登錄后才可以發(fā)表評(píng)論 登錄 | 立即注冊(cè)

廠商推薦

  • Microchip視頻專區(qū)
  • Dev Tool Bits——使用MPLAB® Discover瀏覽資源
  • Dev Tool Bits——使用條件軟件斷點(diǎn)宏來(lái)節(jié)省時(shí)間和空間
  • Dev Tool Bits——使用DVRT協(xié)議查看項(xiàng)目中的數(shù)據(jù)
  • Dev Tool Bits——使用MPLAB® Data Visualizer進(jìn)行功率監(jiān)視
  • 貿(mào)澤電子(Mouser)專區(qū)

相關(guān)在線工具

相關(guān)視頻

關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點(diǎn)地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權(quán)所有   京ICP備16069177號(hào) | 京公網(wǎng)安備11010502021702
快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 99精品影视 | 男女拍拍免费视频30分钟 | 97se狠狠狠狠狠亚洲综合网 | 色一情一伦一区二区三 | 99re这里只有热视频 | 九九久久免费视频 | 国产无限免费观看黄网站 | 欧美精品一区二区三区免费观看 | 亚洲精品国产福利 | 九九香蕉视频 | 国产女同一区二区三区五区 | 中国性天美传媒 | 99国内精品 | 国产h肉在线视频免费观看 国产huangpian视频免费 | 青青操免费在线观看 | 亚洲国产成人精品不卡青青草原 | 亚洲欧美日韩国产专区一区 | 91精品视频网站 | 花季传媒可以看什么 | 精品日韩一区二区 | 欧美日韩一区二区不卡三区 | 失乐园日本版 | 在线国产视频 | 亚洲男人网 | 在线观看国产免费高清不卡 | 成年视频网站免费观看 | 2022国产男人亚洲欧美天堂 | 欧美性福 | 国产特黄特色的大片观看免费视频 | 国产精品香蕉在线观看 | 在线私拍国产福利精品 | 一级片在线观看视频 | 欧美在线观看视频一区 | 在线观看黄页 | 一区二区三区欧美在线 | 国产精品2020观看久久 | 久热99| 国产va免费精品观看精品 | xf在线a精品一区二区视频网站 | 国产va免费精品 | 欧美第八页|