Skip to content

Latest commit

 

History

History
92 lines (52 loc) · 4.74 KB

README.md

File metadata and controls

92 lines (52 loc) · 4.74 KB

这是一个通过单片机在各种屏幕上显示中文的解决方案:

你可能要在TFT屏幕进行显示,也可能要在点阵屏进行显示;无论哪一种都涉及到对于中文的处理,从个人经验上来说,各种常规方法,要么繁琐,要么无法满足各种文字通讯的显示,所以提供软字库的方案就有点必要。

注意:

2024.05.25 性能极大优化,esp8266启动到显示60个字完成,总共时间从1.1秒缩短到了0.5秒。

2024.05.12 新增了faq.rst文件,把日常可能遇到的问题和经验全部放到了这个faq中,建议使用必读。

2024.03.29 调整了xFont的程序结构,以前的调用都是函数式,现在整体封装成了对象,并且tft_espi和arduino_gfx都在x_font中完成。

2024.03.26 做了一些对比测试 :在esp8266下,tft_espi的RAM占用要优于arduino_gfx,但是磁盘占用要稍微多一点,在esp32下两者相差不大;其二,这些显示驱动中不相干的驱动对于ram和flash空间基本没有任何影响,相差只有0.1%;

详情可以访问 : https://blog.csdn.net/platform/article/details/137037441

2024.03.21 同时支持了两个屏幕驱动库tft_eSPI和arduino_gfx ,新增arduino_gfx是因为这个驱动除了支持tft外还支持led。

2024.01.18 修改核心文件命名,避免相关冲突

2024.01.16 字库生成后自动上传到单片机;

2024.01.16 字库的创建和单片机中调用都升级到了64位;

2024.01.15 目前字库的生成和单片机调用都支持了32进制编码;未来是否支持64进制编码待定。

==================== ========================================

文件名 说明
font.rst 整体对于解决方案的说明
src/getunicode.py 使用Python 创建字库
src/getunicodeV2.py 使用Python 创建字库 (目前在用版本)
src/getunicodeV3.py 对创建字库换成了32进制版本,压缩18%的体积,(目前在用版本)
src/main.c 在esp32中调用字库并显示到tft屏幕
lib/ 宋体不同编码和字号的字库

性能指标:

GB2312 字符集创建的字库16号字体,tft_espi 的.vlw格式大约1M,本方案从507k升级到了360k; tft_espi装载并显示中文需要2秒以上,本方案大约0.3秒显示完。

示例使用的是12号字体64进制编码.

字号 16进制(KB) 32进制(KB) 64进制(KB)
12 302 257 213
14 404 331 287
16 507 419 360

提请注意:这只是一个小型的方案,提供思路和代码参考,并且经过验证可行;如果你要使用是在有些地方是需要配套修改的

使用说明:

字体的创建

  • 直接运行 getuncodeV3.py 创建相应的GB2312 完整字符的字库文件
  • 如果只打算创建部分字符的字库,那么就对createFont( FONT_ALL,"P", "simsun.ttc", 12,64) 中的变量FONT_ALL进行赋值,然后运行生产字库;
  • 如果打算使用其他字体,那么把createFont( FONT_ALL,"P", "simsun.ttc", 12,64) 中的simsun.ttc换成其他字体名字就可以了。
  • getuncodeV3.py 创建的字库为了管理方便,命名使用"font/x_f"+str(fontSize)+"_b"+str(binType)+".font" 方式进行存储;
  • 改名字库文件为x.font,放置到arduino项目的data目录下上传到单片机就可以调用了;

写到上面时,我去改了一下代码,实现了字库创建后自动上传到esp32中,牛逼如我,哈哈哈哈

相较于使用PCtoLCD2018对字体进行编码过程,本方案实际使用起来更简单方便,已实现字体生成后自动上传到单片机(需要反注释掉getunicodeV3.py最后一行)。

esp32上调用

  • 包含文件xfont.h;
  • 创建对象 XFont *_xFont,在setup中初始化:_xFont = new XFont();;
  • 调用 _xFont->DrawChinese(10, 10, "业精于勤荒于嬉戏,行成于思毁于随。", GREEN); 在屏幕上输出文字
  • 请参考Main.cpp文件
  • 需要注意的是tft_espi和arduino_gfx的驱动对象名都是tft,但是一个是_xFont.tft调用,另外一个是_xFont->tft调用。

注意:

1,使用不同的屏幕驱动应该在xfont.h中对下面的代码进行不同的注释和反注释

#define ARDUINO_GFX

// #define TFT_ESPI

2,不同屏幕驱动定义的颜色变量不一致,所以需要进行对应的修改;

3,xfont的初始化中被我个人习惯设置成了旋转,例如:tft->setRotation(1); 需要注意调整对应的screenHeight和screenWidth。