新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 基于單片機的智能終端中漢字顯示的處理

基于單片機的智能終端中漢字顯示的處理

作者: 時間:2012-03-16 來源:網(wǎng)絡 收藏

引言

本文引用地址:http://butianyuan.cn/article/171858.htm

近年來,以以及嵌入式系統(tǒng)平臺為基礎的各種廣泛應用于各行各業(yè)的專用設備和產(chǎn)品中,也將逐漸滲透到家用電器和各種消費類電子產(chǎn)品中。

以其價格低廉、技術(shù)成熟而廣泛應用于各種低端產(chǎn)品之中,但是由于的尋址能力有限,限定了其最大的存儲空間。比如最常用的MCS-51單片機,其直接尋址的數(shù)據(jù)存儲空間為64k字節(jié),如果通過擴展來得到更大的存儲空間,既增加了系統(tǒng)成本,也為數(shù)據(jù)讀取操作帶來了不便(對擴展區(qū)間的訪問要通過端口操作實現(xiàn))。所以在單片機系統(tǒng)的設計中,存儲空間的大小是一個很重要的因素。

在PC機上的,是來自存儲在PC機上的庫。庫中的漢字以點陣形式組成。如果以一個16x16點陣的漢字庫作為基本字模庫,每個漢字占32 個字節(jié)。GB2312中規(guī)定了6763個二級漢字,則需要的存儲空間大體為6763×32字節(jié),約200多K字節(jié)。顯然,如果要在單片機終端上漢字,不可能把以上所有的“漢字庫”信息都放在單片機系統(tǒng)的存儲空間中。

40.gif

本文以我實驗室獨立開發(fā)的智能餐飲信息系統(tǒng)為例,首先介紹關(guān)于漢字的基礎知識,然后說明在實際應用中如何對系統(tǒng)漢字庫進行裁減,只保留需要在終端上顯示的“漢字庫”信息,最后介紹在實際應用中會涉及到的有關(guān)字模提取和字模轉(zhuǎn)化的方法。

1:關(guān)于漢字顯示的基礎知識

在中文WIN9X下,我們輸入一個雙八位字節(jié),就得到一個漢字,就會認為這雙八位字節(jié)就是對應這樣的字形,這是錯誤的。這個雙八位字節(jié)被稱為漢字的內(nèi)碼(詳見下文),內(nèi)碼對于字庫來說,只是查找字形的索引。通過這個雙八位字節(jié)可以唯一的從漢字庫中查詢得到其對應的漢字字形數(shù)據(jù)(字模)。對應不同編碼標準的字體,內(nèi)碼對應了不同的字形。我們常用的是國標GB2312信息交換用漢字編碼字符集>>,包含了最常用的簡體中文文字。

如果系統(tǒng)所使用的“漢字庫”中每個漢字按16x16點陣模式存放,則每個漢字由16x16=256個點組成,占用16x2=32個字節(jié)的連續(xù)內(nèi)存單元。每個字節(jié)有8位,每一位都有兩種狀態(tài),即亮或暗,分別用1或0來表示。在16x16點陣中,用各個位的亮暗來表示一個字,凡是筆畫經(jīng)過的地方都為1(亮), 沒有筆畫的地方都為0(暗),這樣就可以表示不同的漢字。

圖1 是“大”字16x16點陣模式排列放大后的結(jié)果。

在PC機中,組成字模的32個字節(jié)默認的排列順序如圖2所示:每行兩個字節(jié),低字節(jié)為DB0~DB7,高字節(jié)為DB8~DB15,每字節(jié)8比特,共16行32個字節(jié)。圖中標出了第1、第2個字節(jié)和第31、第32個字節(jié)的存放位置。

41.gif


上一頁 1 2 3 4 下一頁

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉