2810|4

28

帖子

1

TA的资源

一粒金砂(中级)

楼主
 

国标字库(HZK16,ASC16)使用方法,基本解决Micropython下的中文显示问题 [复制链接]

 
本帖最后由 lemon1394 于 2021-8-23 23:37 编辑

关于字库的问题很多,很多网友的方法各有优缺点,总结如下:

  • 字库需要自己取模,做成TXT立件后,体积庞大,读取算法复杂,不能随心所欲地使用中文。
  • 字库做成字典格式,载入吃内存,读取方便,但是只能放为数不多的几个汉字。
  • 汉字取模软件设置复杂,中途添加困难,经常需要修改。

基于以上问题,字库文件最好是已经生成好的,而且文件体积不能太大,这样只有使用HZK16,ASC16等标准字库更合适。

ASC16字库驱动起来问题不大,可是HZK16就有难度了,最大的问题是编码。

 

ASC16的驱动方法:

ASC16是按ASCII码的顺序排列的二进制文件,打开文件后,只要把文件指针跳转到字符对应的位置,读取16个字节的点阵就可以了。

f.open('ASC16', 'rb')
f.seek((ord('A') * 16)
buf = f.read(16)

f.close

这里的ord()函数返回的是字符的unicode码数值,其实也就是这个字符在unicode码里的序号,ASC16是按ASCII码排序的,所以可以直接取出想要点阵。

可是HZK16不是按unicode码排序的,是按区位码排序,GBK编码,与unicode码并无直接的可运算的应对关系,所以不能直接取出想要的点阵数据。

Python支持GBK编码,可是MicroPython不支持,所以最好的办法是做一个转码表,按unicode编码序号存好每个汉字的区位码。

先在转码表里找到汉字的区位码,再用区位码到HZK16里找对应的点阵,虽然多了一个转码表,但不用轮询,效率还是很高的。

最新回复

可以看看先~   详情 回复 发表于 2023-2-6 09:30
点赞 关注(1)
 
 

回复
举报

6807

帖子

0

TA的资源

五彩晶圆(高级)

沙发
 

在转码表里找到汉字的区位码,再用区位码到HZK16里找对应的点阵,确实是高效

 
 
 

回复

1万

帖子

24

TA的资源

版主

板凳
 
 
 

回复

72

帖子

0

TA的资源

一粒金砂(中级)

4
 

推荐我做的中文支持

https://github.com/wangshujun-tj/mpy-Framebuf-boost-code

比你期望的内容更多

支持文字放大反白,旋转,直至12,16,24,32点阵,支持gb2312和gbk18030多种字库

其他存储库里面有编译好的固件和屏幕示例

点评

可以看看先~  详情 回复 发表于 2023-2-6 09:30
 
 
 

回复

64

帖子

0

TA的资源

一粒金砂(中级)

5
 
wangshujun72 发表于 2023-2-6 08:54 推荐我做的中文支持 https://github.com/wangshujun-tj/mpy-Framebuf-boost-code 比你期望的内容更多 ...

可以看看先~

 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/8 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表