tomzbj 发表于 2023-2-9 15:24:46

[原创] 制作了按unicode顺序排列的HZK系列字库

本帖最后由 tomzbj 于 2023-2-9 15:39 编辑

之前的HZK系列字库是用GB2312内码的, 现在基本UTF-8一统天下了, 再用GB2312很麻烦, 所以干脆把字库也改成unicode顺序的. 当然, 还是只有GB2312字库里的字模, 其他汉字的没有.

见附件, 其中 hzk11 是 bg6agf 大侠提供的, 其他几个来自UCDOS.

U结尾的是稀疏排列的, unicode内码减去0x4e00就是序号, 再分别乘以22/24/28/32就是字模起始地址. 缺点是体积大, 不包括特殊符号/制表符/假名/西里尔字母/希腊字母.
US结尾的是连续排列的, 需要用查找表, 二分查找得到序号, 再乘以22/24/28/32得到起始地址. 体积比较小, 包括特殊符号/制表符/假名, 不过西里尔字母和希腊字母还是没有. 缺点是得二分查找13或者12轮, 效率比较低.
(不知道有没有个合适的hash能提供个介于这两者之间的方案?)

查找表:


效果图:


使用方法(选一即可):

1. 笨办法, 转成c语言数组的形式, 各种网上的*垃*圾*教*程*都喜欢用这种方法. 不推荐.
2. 用objcopy把字库转成.o, 再一起链接到可执行代码. 缺点是编译时有warning消除不了.
3. 写个汇编.s, 加个全局符号, 然后用.incbin把字库包含进来, 然后可以在c程序里调用了. 没有warning, 就是有点麻烦.
4. 最新的c23标准似乎要支持直接include二进制文件了, 有这个就完美了.
5. 直接用stlink/jlink之类字库写到mcu的flash.
前几种方法都要求mcu的flash够大, 毕竟最小的也有100多k.

6. 写到spi flash. 这就无所谓大小了, 就是读取慢了点, spi一定要快, 以及一定得用dma方式读取.
以后有空了再写个缓存, 好在一般应用一屏也显示不了多少汉字, 有1k的缓存能放几十个字模了, 应该够用了.
页: [1]
查看完整版本: [原创] 制作了按unicode顺序排列的HZK系列字库