<li id="8g3ty"><tbody id="8g3ty"><th id="8g3ty"></th></tbody></li>
    <label id="8g3ty"><samp id="8g3ty"></samp></label>
  • <span id="8g3ty"></span>

    1. <center id="8g3ty"><optgroup id="8g3ty"></optgroup></center>
    2. <bdo id="8g3ty"><meter id="8g3ty"><bdo id="8g3ty"></bdo></meter></bdo><center id="8g3ty"><optgroup id="8g3ty"></optgroup></center>
      <label id="8g3ty"><samp id="8g3ty"></samp></label>

    3. 電子開發(fā)網(wǎng)

      電子開發(fā)網(wǎng)電子設(shè)計 | 電子開發(fā)網(wǎng)Rss 2.0 會員中心 會員注冊
      搜索: 您現(xiàn)在的位置: 電子開發(fā)網(wǎng) >> 電子開發(fā) >> 單片機 >> 正文

      單片機 漢字的動態(tài)編碼與顯示方案

      作者:佚名    文章來源:本站原創(chuàng)    點擊數(shù):    更新時間:2010-9-22
      摘要:綜合幾種常用單片機漢字顯示方案,提出一種基于PC機預處理的漢字動態(tài)編碼和動態(tài)字庫的顯示方法,較好地解決了存儲空間、顯示速度、軟件開發(fā)維護幾方面的相互矛盾;具有平臺化的優(yōu)點,同時,給出針對MCS51優(yōu)化的匯編顯示例程。

         關(guān)鍵詞:機內(nèi)碼 動態(tài)編碼 字庫

      因為漢字本身的特點,顯示漢字始終是計算機在我國應用普及的一個障礙。最初,為了能在PC機上顯示、處理漢字,國人發(fā)明了一種硬件設(shè)備"漢卡",后來各種各樣的采用純軟件技術(shù)的中文DOS逐漸成熟,其中、西文軟件的運行速度和性能還是有明顯的差距。最終在軟件進入支持UNICODE、真正實現(xiàn)國際化的WIN95以后,硬件跨入"奔騰"時代,才實現(xiàn)了漢字與西文的統(tǒng)一顯示,但是這一切是以硬件資源的飛速發(fā)展為前提的。以國際GB2312為例,一、二級漢字庫共收錄了6000多個漢字,每個字按16×16點陣計算,字模需要占用32字節(jié)的存儲空間,整個字庫的規(guī)模在200k字節(jié)以上,高點陣(24點陣以上)和矢量字庫以及Windows用的TrueType字體的字庫規(guī)模都是幾兆字節(jié)大小,這在早期的386時代是難以想象的。單片機因為使用靈活、結(jié)構(gòu)簡單、體積小、成本低而在工業(yè)和生活中得到廣泛應用,也正是因此,它的硬件資源很有 限,尋址和計算機能力都遠低于PC機,顯示漢字更受限制。人們不滿足單片機系統(tǒng)采用LED數(shù)碼管的簡單顯示,根據(jù)單片機的特點,開發(fā)出了很多種漢字顯示方法。

      1 幾種常用單片機顯示漢字方法

      (1)采用標準字[1]

      這種方法仿器中文DOS的辦法,將一個標準的漢字庫裝入ROM存儲器,再根據(jù)漢字的機內(nèi)碼在字庫中尋址,找到對應的字模,提取后送到顯示器顯示。因為采用了和PC機相同的編碼(機內(nèi)碼),軟件的開發(fā)和維護非常簡單,基本上與寫PC機軟件差不多。而對單片機系統(tǒng)自身的要求則相對高多了,16×16點陣的字庫需要256K字節(jié),但是一般8位單片機的尋址能力只有64K字節(jié),要進行存儲器擴充,除增加很大一部分硬件成本外,還因為要進行存儲器分頁管理、地址切換,顯示速度明顯受影響,而且只能顯示一種點陣字體。

      (2)直接固化顯示字模[2]

      將要顯示的語句中全部漢字的字模數(shù)據(jù)依次提取出來,順序存放在存儲器中,當顯示時,直接取出字模數(shù)據(jù)送至顯示器即可。這種方法占用空間少,程序?qū)崿F(xiàn)簡單,顯示速度快;但是字模數(shù)據(jù)的提取和存儲安排是一件委有繁瑣的事件,要想大量顯示漢字或進行程序修改幾乎是不可能的,軟件的可維護性很差。

      (3)建立帶索引的小字庫[3]

      將全部要顯示的漢字統(tǒng)一建成一個小字庫,字庫分為2部分:索引素和字模表。索引表由若干定長記錄組成,記錄的內(nèi)容為:漢字機內(nèi)碼、地址碼、識別碼。其中地址碼是該漢字字模在字模表中的位置,識別碼標志該漢字的點陣形式或字體等。字模表中按素引存放漢字字模。顯示漢字時先根據(jù)待顯漢字的機內(nèi)碼在索引表中尋找,找到對應索引記錄后,讀出地址碼和識別碼,再根據(jù)此從字模表中讀出字模,送顯即可。這種方法可根據(jù)實際使用對字庫進行裁剪,硬件開銷較小,但是要進行復雜的查詢運算,字多了平均尋找時間就會變長,效率降低。

      2 漢字動態(tài)編碼

      綜上所述,我們發(fā)現(xiàn):在方法1中,程序員工作量最少,但單片要機的軟、硬件開銷最大;方法2中,單片機的開銷較少,但是編寫和維護軟件極為困難;方法3,介于二者之間。顯然,存儲空間、顯示速度、軟件開發(fā)維護件間存在著矛盾。受各種PC機模擬軟件的啟發(fā),我們提出一種基于PC機預處理的漢字顯示方法--漢字動態(tài)編碼,在實際應用中較好地解決了這一問題。其基本原理如下:建立一種新的編碼機制,這個漢字編碼是動態(tài)的;一個編碼不與某個漢字具體相聯(lián)系,而僅代表某個漢字在字庫中的位置(這個位置也是動態(tài)的);用該碼代替程序里字符串(C語言)或數(shù)據(jù)段(匯編語言)內(nèi)漢字的機內(nèi)碼,單處機顯示程序可根據(jù)這個新的編碼直接在專門建立的動態(tài)小字庫中找到字模,不用進行復雜的尋址、查找等運算,如圖1所示。

      實現(xiàn)漢字動態(tài)編碼的過程就是先進行漢字識別,然后建立編碼字典、提取字模、建立動態(tài)字庫、改寫機內(nèi)碼。首先掃描一遍程序文件,識別其中的漢字,將它們按出現(xiàn)先后順序或機內(nèi)碼的大小排序,重復出現(xiàn)的剔除,建立了一個編碼字典;根據(jù)漢字在編碼字典的位置(序號),可以對漢字按區(qū)碼、位碼進行編碼,也可以采用其它的方法編碼,總之序號與它的動態(tài)編碼存在一一對應關(guān)系;根據(jù)字典中每個漢字的機內(nèi)碼依次從PC機的漢字點陣字庫中提取字模,順序存儲,建立一個小規(guī)模的動態(tài)字庫,這樣每個漢字的字模在字庫中的位置就與其在編碼字典中的序號、動態(tài)編碼一一對應了。最后,再掃描一遍程序文件,按照編碼字典將每個漢字的機內(nèi)碼改寫為對應的動態(tài)編碼。因為程序文件中的漢字隨時會增減,編碼隨之而變,字庫的大小也隨時在變。所以稱之為動態(tài)編碼和動態(tài)字庫。

      考慮一般應用場合,1000個左右的漢字即可滿足要求,按照漢字動態(tài)編碼方法所需的字庫僅為32K字節(jié)大小,只需要1片27256即可,幾乎不用增加什么硬件。這樣,字庫的大小可由漢字的多少控制,程序的編寫和維護可以沿用中文系統(tǒng)下的習慣,僅需要編寫好的單片機程序用PC機進行一次預處理,程序員從繁雜的漢字處理工作中解放出來,有效地降低了軟件和硬件開發(fā)成本。
      \
      3 漢字動態(tài)編碼的具體實現(xiàn)

      實現(xiàn)漢字動態(tài)編碼的關(guān)鍵是建立編碼字典和改寫機內(nèi)碼。下面以是顯示1行漢字"天上有個太陽,水中有個月亮"為例,說明動態(tài)編碼的實現(xiàn)過程。

      (1)漢字識別

      漢字在PC機內(nèi)的存儲和處理是用機內(nèi)碼來實現(xiàn)的。每個漢字的機內(nèi)碼是唯一的,由2個字節(jié)組成,分區(qū)碼和位碼,為了和西文的ASCII碼有區(qū)別,漢字機內(nèi)碼的區(qū)碼和位碼的取值都大于0A0H。我們要處理的源程序文件都是文本文件,存儲的都是西文字符、控制符的ASCII碼和中文字符的機內(nèi)碼,當掃描到文件中大于0A0H的字節(jié)內(nèi)容時,即可判斷該字節(jié)是漢字機內(nèi)碼的1個字節(jié),而且肯定是成對出現(xiàn),第1個字節(jié)是區(qū)別,第2個字節(jié)是位碼,都大于0A0H,否則出錯。

      在C和匯編程序中表示字符的方式有所不同,但最終字符在文件中的存儲格式是一樣的。顯示上面那行漢字,用C語言可以表示為:

      char OneSent[]="天上有個太陽,水中有個月亮";

      printfhz(OneSent);/*printfhz()顯示函數(shù)*/

      用十六進制編輯器(我們用的是UEdit32)察看文件中C語言字符串定義語句為:

      63 68 61 72 20 20 4F 6E 65 53 65 6E 74 5B 5D 20 3D 20 22 CC EC C9 CF D3 D0 B8 F6 CC AB D1 F4 A3 AC CB AE D6 D0 D3 D0 B8 F6 D4 C2 C1 C1 22 20 3B 0D 0A

      用匯編語言可以表示為:

      ONESENT:DB ‘天上有個太陽,水中有個月亮‘,00H

      MOV DPTR,ONESENT

      LCALL DISPLAY;DISPLAY是顯示子程序

      用十六進制編輯器察看上面用匯編語言定義字符串的那一條語句為:

      4F 4E 45 53 45 4E 54 3A 44 42 20 27 CC EC C9 CF D3 D0 B8 F6 CC AB D1 F4 A3 AC CB AE D6 D0 D3 D0 B8 F6 D4 C2 C1 C1 27 2C 30 30 48 0D 0A

      由此可以觀察到情況確如前所述。

      (2)建立編碼字典

      編碼字典是在掃描的同時逐步建立起來的,每掃描到一個漢字(包括全角符號),即與字典中已有的字符進行比較,如沒有重復,是新的字符就順序存入字典,否則繼續(xù)掃描,直至文件結(jié)屬。由于每個字符都是從尾部添加的,它們的序號也是依次遞增的,根據(jù)序號就可以進行動態(tài)編碼了。由于顯示的漢字一般都得在256個以上,即使進行動態(tài)編碼,也需要用2字節(jié)編碼來實現(xiàn)。以MCS51系列單片機和16×16點陣漢字做一優(yōu)化編碼示例:8051的地址指針DPTR是16位指針,由高、低2字節(jié)指針DPH、DPL組合而成,如果將存儲器按0FFH(256)字節(jié)分布,修改DPH即可直接尋址到任一頁,修改DPL可尋址該頁的任一字節(jié)。一個16×16點陣漢字的字模是32字節(jié)大小,每頁存儲器正好能容納8個漢字字模。可以優(yōu)化設(shè)計動態(tài)編碼的高字節(jié)指向字模的頁地址(DPH),低字節(jié)指向字模在該頁的首地址(DPL)。考慮地址空間的有效分配,將字庫的地址放在0A000H以后(程序或數(shù)據(jù)存儲器均可),動態(tài)編碼的高字節(jié)要加上地址有效分配,將字庫的地址放在0A000H以后(程序或數(shù)據(jù)存儲器均可),動態(tài)編碼的高字節(jié)要加上地址的頁偏移量(大于等于0A0H);考慮漢字與西文字符的區(qū)別,動態(tài)編碼的低字節(jié)也需要加上一個大于或等于0A0H的偏移量。設(shè)某漢字在編碼字典中的序號為Num,則該漢字的動態(tài)編碼為:

      動態(tài)編碼高字節(jié)=頁偏移量+Num/8

      動態(tài)編碼低字節(jié)=偏移量+(Num%8)×32    (1)

      偏移量一般可設(shè)為0A0H。當單片機顯示某個漢字時,只需將其動態(tài)編碼的高字節(jié)送DPH,低字節(jié)減0A0H后送DPL,即可得到對應字模的地址指針。

      (3)提取字模、建立動態(tài)字庫

      漢字機內(nèi)碼與點陣字庫的詳細關(guān)系可參考有關(guān)資料,它們存在如下聯(lián)系:

      字模首地址=((機內(nèi)碼高字節(jié)-1)×94+(機內(nèi)碼低字節(jié)-1))×N    (2)

      注:N為一個漢字點陣字模的字節(jié)數(shù)。

      按照編碼字典內(nèi)容,根據(jù)字模首地址,依次取出漢字字模,順序?qū)懭胍粋二進制文件,即建成動態(tài)字庫(其它方法略),用燒錄器寫入EPROM,就可以使用了。

      (4)編碼改寫

      機內(nèi)碼是PC機識別處理漢字用的,單片機只能處理我們建立起來的動態(tài)編碼,還得把程序中漢字的僅機碼根據(jù)編碼字典改成對應的動態(tài)編碼才行。由于在編寫源程序的文本編輯器中看到的是經(jīng)過系統(tǒng)處理過的字節(jié),看不到漢字的機內(nèi)碼,也無法對其進行改寫。根據(jù)"漢字識別"一節(jié)所述,不經(jīng)過文本編輯器,直接將動態(tài)編碼(十六進制數(shù))定改磁盤文件對應位置即可,但是處理過后的漢字在文本編輯器里會顯示出亂碼。

      (5)漢字顯示

      在明白了動態(tài)編碼與動態(tài)字庫中字模的關(guān)系后,可以完成按照PC機下漢字顯示原理進行單片機下的程序設(shè)計,編寫前面的函數(shù)printhz()或子程序的DISPLAY,可參考相關(guān)資料[4]。
      \
      4 MCS51漢字顯示例程

      根據(jù)上述漢字動態(tài)編碼方法,我們利用Borland C++編寫了PC機預處理程序,將ASM51或C51源程序用PC機預處理后,建立了動態(tài)字庫和改寫了機內(nèi)碼,并且用ASM51寫了一個針對MCS51進行優(yōu)化的子程序DIS_CHAR。它顯示一個西文或中文字符,實現(xiàn)過程如圖2所示。

      西文字符碼的顯示與流字顯示基本相同,將西文字庫(僅數(shù)字和字符部分)裝入程序存儲器中,根據(jù)ASCII碼的值計算出字模首地址,將字符字模依次讀出,再送顯示即可。

      此方案不但可用于單片機系統(tǒng)中,還可應用于任何無中文系統(tǒng)支持的嵌入式系統(tǒng)中。根據(jù)這個思路還可設(shè)計出不同字體、點陣混合的字庫,支持包含2萬多個字符的新國標編碼,甚至矢量字體在單片機系統(tǒng)中的應用也成為可能。由于技術(shù)水平有限,此方案還存在一些不足之處,如改寫編碼后源程序中漢字顯示為亂碼,不知道改碼處理是否正確,操作比較繁瑣。如果能采用插件技術(shù)實現(xiàn)此方案,編輯器中能正常顯示漢字,而輸出已經(jīng)是改碼后的程序文件,則能很好地解決上述不足。在這里,我們拋碼引玉,希望有興趣的朋友一起合作,實現(xiàn)單片機中文顯示的廣義開發(fā)平臺。

      Tags:單片機,漢字編碼,顯示方案  
      責任編輯:admin
      請文明參與討論,禁止漫罵攻擊,不要惡意評論、違禁詞語。 昵稱:
      1分 2分 3分 4分 5分

      還可以輸入 200 個字
      [ 查看全部 ] 網(wǎng)友評論
      關(guān)于我們 - 聯(lián)系我們 - 廣告服務 - 友情鏈接 - 網(wǎng)站地圖 - 版權(quán)聲明 - 在線幫助 - 文章列表
      返回頂部
      刷新頁面
      下到頁底
      晶體管查詢
      主站蜘蛛池模板: 久久婷婷色香五月综合激情| 狠狠色婷婷狠狠狠亚洲综合| 一本色道久久88加勒比—综合| 一本一道久久综合狠狠老| 亚洲综合精品网站| 色综合色综合色综合色综合网| 久久婷婷色香五月综合激情| 一本综合久久国产二区| 99久久婷婷免费国产综合精品| 人人狠狠综合久久88成人| 五月综合色婷婷影院在线观看| 中文网丁香综合网| 伊人网综合在线视频| 色综合久久综合网| 亚洲国产品综合人成综合网站| 狠狠88综合久久久久综合网| 亚洲日韩久久综合中文字幕| 亚洲欧洲日韩国产综合在线二区 | 国产综合久久久久久鬼色| 99久久国产综合精品五月天| 精品久久综合1区2区3区激情| 色综合久久久久综合99| 99久久综合精品免费| 色婷婷久久综合中文久久蜜桃av| 一本一本久久a久久精品综合 | 色综合视频一区二区三区| 精品综合久久久久久97| 久久香综合精品久久伊人| 一本久久a久久精品综合夜夜| 九九久久99综合一区二区| 国产精品国色综合久久| 亚洲另类激情综合偷自拍| 91精品国产色综合久久不| 婷婷色中文字幕综合在线| 亚洲国产成人综合精品| 国产综合视频在线观看一区| 另类小说图片综合网| 亚洲国产精品综合久久网络 | 99久久综合精品免费| AV狠狠色丁香婷婷综合久久| 狠狠色狠狠色综合系列|