STM32CubeIDE结合汉字取模在LCD输出字体经验分享

STM32CubeIDE结合汉字取模在LCD输出字体经验分享

一、汉字取模工具

嵌入式LCD屏显示无非就是不间断刷新LCD宽度*LCD高度的像素矩阵,并为每个像素指定特定颜色。对于LCD屏幕显示汉字,无非就是将字体形状转换为字体宽度*字体高度的像素矩阵,及指定每个字体像素的颜色,然后在LCD屏幕指定位置按字体宽度*字体高度的像素矩阵进行刷新渲染。

汉字取模工具可以设置汉字显示的行、列像素大小,设置字体类型等信息,将输入的每个字符转换成指定行宽、列宽的二进制矩阵,在该矩阵中,字体覆盖区域采用1标记、字体不覆盖区域采用0标记。

二、汉字取模配置

我们双击LcmZimo.exe打开,取模工具界面如下,红框部分是字体相关参数设置,篮框部分是图片参数设置(通常用于各种艺术字体、图片像素等):

dad45ae29967412094c3ef30ea54fd87.png (187.74 KB, 下载次数: 15)

下载附件

保存到相册

2023-4-6 19:12 上传

现在来制作24*24矩阵的“嵌入式开发测试!”的字体编码表,如下图进行设置。

a6da1cc46b4740c3a74302a6a4434f35.png (202.04 KB, 下载次数: 5)

下载附件

保存到相册

2023-4-6 19:12 上传

最终得到字符编码表:

2359940c46ca4d39baaf9f54abec8a17.png (253.33 KB, 下载次数: 7)

下载附件

保存到相册

2023-4-6 19:12 上传

点击保存,将字符编码表输出为头文件“pytest.h”,如下图:

9867dd20e996493e826540c40f5fbada.png (157.26 KB, 下载次数: 7)

下载附件

保存到相册

2023-4-6 19:12 上传

三、创建工程

本文基于STM32L496VGT3的MCU创建一个新工程,并提前实现了lpusart串口驱动、三个按键及三个LED灯驱动、以及OLED屏幕驱动(SPI引脚)

假定已经实现了这些基本功能,在此基础上实现OLED屏幕显示刚刚定义汉字“嵌入式开发测试!”。

四、汉字LCD显示设计

将刚才取模软件保存输出的pytest.h头文件拷贝到ICore/oled目录下,本文对pytest.h做了细微调整(去除一些不规范编程告警,不调整无影响):

69005a7ea375474fb7c57bb52c883ced.png (98.7 KB, 下载次数: 6)

下载附件

保存到相册

2023-4-6 19:12 上传

取模软件针对每个字符输出了一个72字节的8bit的数值,也就是72字节*8bit=576bit=24*24像素,目前该字符编码在取模软件上设置是横向取模左高位,数据排列:从左到右从上到下,就意味着,每3个字节*8bit=24bit表示一行的像素,如前三个字符0X00 0X18 0X00->0000 0000 0001 1000 0000 0000,作为“嵌”字第一行像素标记,位数值为1的填充前景色,为0的填充背景色。具体代码如下:

//绘制每个字符,24*24像素大小

void OLED_DISPLAY_24x24(uint8_t xpos, uint8_t ypos,uint8_t index)

{

uint16_t textData[24][24]={0}; //24*24大小颜色矩阵

FNT_GB24 cur_text = code_GB_24[index];

for(uint8_t i=0;i<72;i++){

for(uint8_t j=0; j<8; j++)

if(cur_text.Msk[i]&(0x01<<(8-j))){

textData[i/3][(i%3)*8+j] = LCD_DISP_BLUE;//前景色,蓝色

}else{

textData[i/3][(i%3)*8+j] = LCD_DISP_BLACK;//背景色,黑色

}

}

for(uint8_t i=0; i<24; i++)

{

OLED_WriteLine(xpos,ypos+i,textData[i],24);//列像素渲染

}

}复制代码

上述代码中,每个汉字72字节编码表,3个字节表示一行(列宽3*8bit=24),共24行(72字节/3=24),构成24*24的二进制矩阵,然后根据该二进制矩阵,为1的给与前景色,为0的给与背景色,从而得到24*24的颜色矩阵,然后在渲染时在24*24像素的LCD区域渲染对应的颜色,形成屏幕显示输出。

然后逐个字符绘制输出,完成前面输入字段“嵌入式开发测试!”的全部输出:

void BSP_LCD_login(uint8_t xpos, uint8_t ypos)

{

BSP_LCD_Clear_DMA(LCD_DISP_BLUE);

for(uint8_t index=0; index<8;index++)

{

OLED_DISPLAY_24x24(xpos+index*24,ypos,index);

}

}复制代码

五、汉字输出测试

在主循环函数中,按键KEY0时,屏幕输出显示“嵌入式开发测试!”字段:

6ed62e52730f4575b6fd12358d1344a1.png (122.57 KB, 下载次数: 4)

下载附件

保存到相册

2023-4-6 19:12 上传

编译及下载:

e9dd817922e248ccaeacdb5d33411c55.png (109.82 KB, 下载次数: 5)

下载附件

保存到相册

2023-4-6 19:12 上传

按键KEY0,屏幕输出显示如下:

7bb63e40a0994f8bbd59a704db07964b.png (200.68 KB, 下载次数: 8)

下载附件

保存到相册

2023-4-6 19:12 上传

————————————————

版权声明:py_free-物联智能

如有侵权请联系删除

相关

湖南通道侗锦色彩形成及其运用规律
365体育投注提款

湖南通道侗锦色彩形成及其运用规律

📅 08-08 👁️ 9846
hey five:看臉社交?人們為什麼會接受陌生人給自己顏值打分
诜诲是什么意思
365体育投注提款

诜诲是什么意思

📅 09-07 👁️ 8060