博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
GB2312编码
阅读量:6302 次
发布时间:2019-06-22

本文共 971 字,大约阅读时间需要 3 分钟。

在区码和位码的基础上,分别加上0XA0的偏移,便是GB2312编码;

 

 

 

 

 

 

 

 

 

 

 

我们制作ASCII字库时,一般只做可以显示出来的字符字模,前面命令型的ASCII字符,我们不做字模,即从“空格开始”,ASCII表对应0x20,所以当我们使用PCtoLcd的16X16选项制作字库时,(注意英文的实际占用的是8X16,要比汉字小半个字宽),所以,如果根据标准ASCII表制作字库时,可以根据字符的汉字相对于“空格”的偏移找到对应字库中的偏移地址,找到对应的字模;如找到"A"对应的字模:Address = ("A" - " ") X (8 X 16 )/8,从这个偏移地址向后连续取16个字节,即是"A"的所有字模 。

 

GB2312是在区位码的地址基础上分别偏移0xA0,每个区有94个汉字;每个汉字占用的字节为(16X16)/8=32个字节;汉字字库的第一个字符也是“空格”,但这个是全角的和ASCII的不一样;如我们再写液晶驱动程序显示一个英文字母时,void (uchar x,uchar y,uchar en)   可以这样寻找偏移='en'-' '  。

该空格的区位码是“0101”,所以任意一个汉字的偏移地址公式是,Address= ( (CodeH-0x30-1)*94+(CodeL-0x30-1) )*( 16*16 )/8;CodeH是GB2312的第一个字节,CodeL是GB2312的第二个字节,减一 是因为区位码是从第一区开始的,而字模数组表是从0开始的;  (以上的计算均是按16*16取模时计算的)

当我使用单片机编程工具写程序时,编译的时候,编译器会根据我们的选择(如MDK)会自动将字符串转换成机内码即GB2312形式进行存储,所以我们可以根据GB2312与区位码的关系进行寻找地址偏移。如我们在液晶驱动程序中写一个中文汉字显示程序,void(uchar x,uchar y,uint16 hz )   可以这样找区位码,CodeH=hz>>8;  CodeL=hz&0x00ff;  

注意英文和汉字的参数定义类型一个是8位uchar 型的,一个是u16位int16型的,因为GB2312在系统中是占用2个字节的,英文只占用一个字节

 

 

 

转载于:https://www.cnblogs.com/wolf-man/p/6617010.html

你可能感兴趣的文章
Geoserver端口冲突解决方案
查看>>
MySQL数据库改名字
查看>>
如何重启MySQL,正确启动MySQL
查看>>
public,protected,privat区别
查看>>
Webpack使用教程六(Plugins)
查看>>
从外国html5网站上扒来一个鼠标经过的css3 效果,感觉很不错
查看>>
世界最大漏洞数据库发布最新研究报告
查看>>
c#实现图片二值化例子(黑白效果)
查看>>
CurrentCulture和CurrentUICulture的区别
查看>>
Spring学习(22)--- AOP之Advice应用(下)
查看>>
A302应用开发中基础功能的经验总结
查看>>
【Python开发】Python中数据分析环境的搭建
查看>>
cocos2d-x simpleGame 0
查看>>
xpath语法大全
查看>>
oracle exists / in
查看>>
tortoise更新后eclipse项目挂掉,报错找不到类
查看>>
20155225 2016-2017-2 《Java程序设计》第六周学习总结
查看>>
IO模型
查看>>
[java][jboss]改变jboss部署目录(虚拟目录)
查看>>
第十五周进度条
查看>>