91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于BMP文件格式存儲(chǔ)漢字字庫的漢字顯示解決方案

電子設(shè)計(jì) ? 來源:現(xiàn)代電子技術(shù) ? 作者:何英高 ? 2021-03-17 13:48 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1 引 言

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

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

高通手機(jī)平臺(tái)Brew字符顯示由兩部分構(gòu)成,一部分為上層應(yīng)用提供一個(gè)統(tǒng)一的字符顯示接口部分,另一部分為某一種字符集或字體具體實(shí)現(xiàn)部分,這兩個(gè)部分是通過虛函數(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ù):

現(xiàn)代電子技術(shù)

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

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

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

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

從上面的存儲(chǔ)結(jié)構(gòu)可知,他實(shí)際就是一幅BMP格式的漢字字庫圖片,這幅BMP圖片就是漢字字符集的二進(jìn)制表示,他是從BMP圖片格式轉(zhuǎn)換過來的。這里每個(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ù)把漢字顯示出來。該方法具有最大的靈活性,甚至不理睬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)陣顯示等把漢字顯示出來。然后把該自己開發(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)陣顯示的全過程,并使用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ù),通過這個(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表示的漢字字庫;

int cbBitmap:用BMP表示的漢字字庫總的字節(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)字庫的漢字顯示方式,主要工作集中于下面兩個(gè)方面:

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

在Brew方案中,上層應(yīng)用模塊都是通過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)買字庫,為了能夠應(yīng)用第三方字庫到高通手機(jī)平臺(tái)上需要轉(zhuǎn)換成BMP格式的文件。另一個(gè)要注意的問題是這里把漢字顯示作為單獨(dú)的一個(gè)字符集來考慮的,在實(shí)際中可以把ASCII,漢字和漢字偏旁部首構(gòu)成一個(gè)字符集來考慮。只要根據(jù)不同的碼值分別計(jì)算他們各自對(duì)應(yīng)BMP圖形的偏移量即可。

6 結(jié) 語

本文就高通手機(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)用需要注意問題。

責(zé)任編輯:gt

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 高通
    +關(guān)注

    關(guān)注

    78

    文章

    7740

    瀏覽量

    200039
  • 手機(jī)
    +關(guān)注

    關(guān)注

    36

    文章

    7001

    瀏覽量

    161111
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    智能顯示模塊帶字庫嗎?可以支持哪些字體顯示

    智能顯示模塊帶字庫嗎?可以支持哪些字體顯示?
    發(fā)表于 02-26 10:47

    技術(shù)資訊 I 一文詳解 STEP 文件

    本文要點(diǎn)STEP文件是一種廣泛使用的中性文件格式,用于交換3D計(jì)算機(jī)輔助設(shè)計(jì)(CAD)數(shù)據(jù)。STEP文件分為多種類型,適用于特定行業(yè)領(lǐng)域及產(chǎn)品開發(fā)的全流程。雖然STEP文件格式主要用于
    的頭像 發(fā)表于 02-06 16:08 ?915次閱讀
    技術(shù)資訊 I 一文詳解 STEP <b class='flag-5'>文件</b>

    西門子字庫文件使用手冊(cè)

    西門子字庫文件使用手冊(cè)
    發(fā)表于 12-23 09:54 ?0次下載

    電能質(zhì)量在線監(jiān)測(cè)裝置的數(shù)據(jù)壓縮存儲(chǔ)功能支持的數(shù)據(jù)格式可以修改嗎?

    電能質(zhì)量在線監(jiān)測(cè)裝置的數(shù)據(jù)壓縮存儲(chǔ)功能支持的數(shù)據(jù)格式 部分可修改 ,具體取決于格式類型(數(shù)據(jù)文件格式 / 壓縮算法格式)與廠家設(shè)計(jì),核心結(jié)論
    的頭像 發(fā)表于 12-11 16:39 ?1145次閱讀
    電能質(zhì)量在線監(jiān)測(cè)裝置的數(shù)據(jù)壓縮<b class='flag-5'>存儲(chǔ)</b>功能支持的數(shù)據(jù)<b class='flag-5'>格式</b>可以修改嗎?

    工業(yè)級(jí)-專業(yè)液晶圖形顯示加速器RA8889ML3N簡(jiǎn)介+顯示方案選型參考表

    支持:豐富API資源,電路原理圖,圖片和視頻轉(zhuǎn)換工具,各國(guó)語言的Unicode字庫代碼解決方案,Demo開發(fā)板,F(xiàn)lash燒錄工具等。
    發(fā)表于 11-14 16:03

    Jtti分析SSL證書安裝不成功是怎么回事?有哪些原因?

    。本文Jtti.cc將探討一些常見的SSL證書安裝失敗的原因,并提供相應(yīng)的解決方案。 1.證書文件或密鑰文件格式錯(cuò)誤 SSL證書的安裝需要正確格式的證書
    的頭像 發(fā)表于 10-27 16:15 ?656次閱讀

    rt-thread程序中的漢字字符串,如何提取漢字的gb2312編碼?

    我希望程序中的漢字字串“歡迎光臨”取出來的字節(jié)數(shù)組是GB2312碼:“BB B6 D3 AD B9 E2 C1 D9 00”, 而實(shí)際出來的是UTF-8碼:“E6 AC A2 E8 BF 8E E5
    發(fā)表于 09-29 07:14

    【六岳微LY-F335開發(fā)板試用體驗(yàn)】OLED顯示和調(diào)試過程中的坑

    \\\\\\\\_loop\\\\\\\\(\\\\\\\\); \\\\\\\\} 調(diào)試過程中發(fā)現(xiàn)BMP顯示漢字占據(jù)存儲(chǔ)單元太大,導(dǎo)致CMD
    發(fā)表于 09-22 19:17

    一文讀懂WAV音頻文件格式

    本文主要為后面ESP32 I2S音頻系列文章做鋪墊,所以本篇將介紹WAV音頻文件格式,并通過C代碼生成一段1S的正弦波WAV音頻寫入到SD卡里面。
    的頭像 發(fā)表于 08-25 17:49 ?5255次閱讀
    一文讀懂WAV音頻<b class='flag-5'>文件格式</b>

    淺談電子工程師困惑多年的EDA行業(yè)的標(biāo)準(zhǔn)格式

    話說每個(gè)行業(yè)有每個(gè)行業(yè)的標(biāo)準(zhǔn),工業(yè)軟件領(lǐng)域文件格式也有達(dá)成一定程度默契,比如不同CAD軟件有自己獨(dú)特的格式,為了各自的用途,有的可以滿足不同的曲面,特殊圖形的處理,有的是為了輕量化需求。工具之間交換
    的頭像 發(fā)表于 08-23 12:34 ?735次閱讀
    淺談電子工程師困惑多年的EDA行業(yè)的標(biāo)準(zhǔn)<b class='flag-5'>格式</b>

    零知開源——STM32F4結(jié)合BMP581氣壓傳感器實(shí)現(xiàn)ST7789中文顯示教程

    屏 ST7789 SPI 數(shù)據(jù)可視化顯示 接口擴(kuò)展 零知擴(kuò)展板 - 提供標(biāo)準(zhǔn)接口 1.2 接線方案零知增強(qiáng)板(STM32F407VET6) BMP581(I2C) ST7789(SPI) 引腳功能
    發(fā)表于 07-08 18:55

    零知開源——STM32F1驅(qū)動(dòng)BMP581壓強(qiáng)傳感器使用SPI實(shí)現(xiàn)ST7789顯示的環(huán)境監(jiān)測(cè)系統(tǒng)

    3.3 串口監(jiān)視器數(shù)據(jù)同時(shí),串口監(jiān)視器將每秒輸出一次數(shù)據(jù): 四、SPI沖突解決方案詳解 4.1 問題現(xiàn)象 當(dāng)BMP581和ST7789共享硬件SPI總線時(shí):顯示屏無法正常顯示
    發(fā)表于 07-03 17:26

    用CubeMX生成代碼時(shí)會(huì)將main.c文件中的漢字變成亂碼,怎么解決?

    使用CubeMX生成代碼時(shí),經(jīng)常會(huì)遇到原main.c文件中的漢字全部變成亂碼,如下圖所示: 將這些亂碼字符重新修改后,只要再次用CubeMX生成代碼,這些漢字又會(huì)成為亂碼,請(qǐng)問該如何設(shè)置才能
    發(fā)表于 06-23 08:02

    服務(wù)器數(shù)據(jù)恢復(fù)—ocfs2文件系統(tǒng)被格式化為Ext4文件系統(tǒng)的數(shù)據(jù)恢復(fù)案例

    服務(wù)器存儲(chǔ)數(shù)據(jù)恢復(fù)環(huán)境&故障: 人為誤操作將Ext4文件系統(tǒng)誤裝入一臺(tái)服務(wù)器存儲(chǔ)上的Ocfs2文件系統(tǒng)數(shù)據(jù)卷上,導(dǎo)致原Ocfs2文件系統(tǒng)被
    的頭像 發(fā)表于 06-10 12:03 ?786次閱讀
    服務(wù)器數(shù)據(jù)恢復(fù)—ocfs2<b class='flag-5'>文件</b>系統(tǒng)被<b class='flag-5'>格式</b>化為Ext4<b class='flag-5'>文件</b>系統(tǒng)的數(shù)據(jù)恢復(fù)案例

    CCG4十六進(jìn)制文件格式是什么?

    你好,先生, 我可以知道 CCG4 十六進(jìn)制文件格式嗎? 2055 行是什么意思?
    發(fā)表于 05-15 07:22