求一个stm8s 的25QFlash存的字库程序

2019-12-27 19:01发布

rt,自己从stm32移植,但是没有成功 乱码,能够检测到字库的存在。如果那个大哥有,就给小弟一份
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
20条回答
冬天的野狼V2
1楼-- · 2019-12-27 20:57
用库写的最好,寄存器看不懂
3goodboy
2楼-- · 2019-12-27 23:14
 精彩回答 2  元偷偷看……
johnlj
3楼-- · 2019-12-28 02:50
给你个GB2312的规范吧,自己看看,很简单
johnlj
4楼-- · 2019-12-28 08:36
GB2312汉字是由两个字节编码的,范围为A1A1~FEFE。A1-A9为符号区,B0到F7为汉字区。每一个区有94个字符(注意:这只是编码的许可范围,不一定都有字型对应,比如符号区就有很多编码空白区域)。下面以汉字“我”为例,介绍如何在HZK16文件中找到它对应的32个字节的字模数据。

前面说到一个汉字占两个字节,这两个中前一个字节为该汉字的区号,后一个字节为该字的位号。其中,每个区记录94个汉字,位号为该字在该区中的位置。所以要找到“我”在hzk16库中的位置就必须得到它的区码和位码。(为了区别使用了区码和区号,其实是一个东西,别被我误导了)

区码:区号(汉字的第一个字节)-0xa0    (因为汉字编码是从0xa0区开始的,所以文件最前面就是从0xa0区开始,要算出相对区码)

位码:位号(汉字的第二个字节)-0xa0

这样我们就可以得到汉字在HZK16中的绝对偏移位置:

offset=(94*(区码-1)+(位码-1))*32

注解:1、区码减1是因为数组是以0为开始而区号位号是以1为开始的

            2、(94*(区号-1)+位号-1)是一个汉字字模占用的字节数

           3、最后乘以32是因为汉字库文应从该位置起的32字节信息记录该字的字模信息(前面提到一个汉字要有32个字节显示)
冬天的野狼V2
5楼-- · 2019-12-28 11:04
3goodboy 发表于 2016-6-25 09:35
拿原子stm32的程序改吧

我就是拿原子的改,改出来乱码
fengchi
6楼-- · 2019-12-28 12:49
看风驰的例程

一周热门 更多>