来源 | 嵌入式应用研究院 整理&排版 | 嵌入式应用研究院
之前在LVGL模拟器CodeBlock上写了一个多语言的demo,用于学习LVGL多国语言的应用,如下所示:
后来我将其移植到小熊派开发板以后,结果就成了这样,连控件显示的位置都变了(控件移位的具体原因不详,待后续分析LVGL源代码):
这一看就是编码问题。按以往的经验,直接在工程目录下找到有中文字符串的这个文件,用notepad
将其转成utf-8
,然后直接保存再重新打开Keil MDK就可以了,那么试试吧:
接下来打开MDK工程,重新编译,出现了6个Error:
1、排坑找错
错误原因显示的是调用宏的参数过多,但实际上这就只是传了一个参数呀...不应该,我开始怀疑编译器是否支持宽字符显示的问题,因此搜索Keil MDK
帮助手册看到了这一项:
按照文档的指示,我在Misc Controls这个配置项上添加了--no-multibyte-chars
,然后重新编译工程:
接下来再将其下载到开发板上:
最终显示正常。
2、核心原因
通过STM32CubeMX生成的程序源文件的编码格式并不是UTF-8
或者UTF16
,因此如果在某些文件下写中文以及一些特殊国家语言字符则需要手动对该文件进行转换。如果源文件编码为 UTF-8 或 UTF-16,并且文件以字节顺序标记开头,则编译器将忽略 --locale 和 --[no_]multibyte_chars 选项并将文件解释为 UTF-8 或 UTF- 16。
3、正确做法
通常做多语言显示,我们需要将每个不同国家的语言需要单独拧到不同的文件中,然后将其单独进行转码,以方便进行统一管理,例如3D打印机固件Marlin
代码,就是这么做的:
而一些模拟显示软件,编码环境较为完善,很多坑其实已经帮我们提前排除了,因此在面对一些编码环境没有那么完善的平台来说,了解环境配置以及一些编码规则则更有利于我们定位问题。如果你有更好的方法,欢迎评论区留言,一起交流LVGL应用技术。目前应用例程还在修改中,后续将会共享到Github或者Gitee,地址将在评论区给出。下期将分享如何将按键模拟旋转编码器来实现键盘输入。