新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > 基于单片机的智能终端中汉字显示的处理

基于单片机的智能终端中汉字显示的处理

作者:时间:2012-03-16来源:网络收藏

引言

本文引用地址:http://www.amcfsurvey.com/article/171858.htm

近年来,以以及嵌入式系统平台为基础的各种广泛应用于各行各业的专用设备和产品中,也将逐渐渗透到家用电器和各种消费类电子产品中。

以其价格低廉、技术成熟而广泛应用于各种低端产品之中,但是由于的寻址能力有限,限定了其最大的存储空间。比如最常用的MCS-51单片机,其直接寻址的数据存储空间为64k字节,如果通过扩展来得到更大的存储空间,既增加了系统成本,也为数据读取操作带来了不便(对扩展区间的访问要通过端口操作实现)。所以在单片机系统的设计中,存储空间的大小是一个很重要的因素。

在PC机上的,是来自存储在PC机上的库。库中的汉字以点阵形式组成。如果以一个16x16点阵的汉字库作为基本字模库,每个汉字占32 个字节。GB2312中规定了6763个二级汉字,则需要的存储空间大体为6763×32字节,约200多K字节。显然,如果要在单片机终端上汉字,不可能把以上所有的“汉字库”信息都放在单片机系统的存储空间中。

40.gif

本文以我实验室独立开发的智能餐饮信息系统为例,首先介绍关于汉字的基础知识,然后说明在实际应用中如何对系统汉字库进行裁减,只保留需要在终端上显示的“汉字库”信息,最后介绍在实际应用中会涉及到的有关字模提取和字模转化的方法。

1:关于汉字显示的基础知识

在中文WIN9X下,我们输入一个双八位字节,就得到一个汉字,就会认为这双八位字节就是对应这样的字形,这是错误的。这个双八位字节被称为汉字的内码(详见下文),内码对于字库来说,只是查找字形的索引。通过这个双八位字节可以唯一的从汉字库中查询得到其对应的汉字字形数据(字模)。对应不同编码标准的字体,内码对应了不同的字形。我们常用的是国标GB2312信息交换用汉字编码字符集>>,包含了最常用的简体中文文字。

如果系统所使用的“汉字库”中每个汉字按16x16点阵模式存放,则每个汉字由16x16=256个点组成,占用16x2=32个字节的连续内存单元。每个字节有8位,每一位都有两种状态,即亮或暗,分别用1或0来表示。在16x16点阵中,用各个位的亮暗来表示一个字,凡是笔画经过的地方都为1(亮), 没有笔画的地方都为0(暗),这样就可以表示不同的汉字。

图1 是“大”字16x16点阵模式排列放大后的结果。

在PC机中,组成字模的32个字节默认的排列顺序如图2所示:每行两个字节,低字节为DB0~DB7,高字节为DB8~DB15,每字节8比特,共16行32个字节。图中标出了第1、第2个字节和第31、第32个字节的存放位置。

41.gif


上一页 1 2 3 4 下一页

评论


相关推荐

技术专区

关闭