欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

基于SPI/IIC接口的OLED数据显示

程序员文章站 2022-03-01 16:38:50
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录前言一、pandas是什么?二、使用步骤1.引入库2.读入数据总结前言提示:这里可以添加本文要记录的大概内容:例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。提示:以下是本篇文章正文内容,下面案例可供参考一、pandas是什么?示例:pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。二、使用步骤1.引入库代码...


实验目标

我们学习理解了OLED屏显和汉字点阵编码原理,现在来使用STM32F103的SPI或IIC接口实现以下三个功能:

  1. 显示自己的学号和姓名;

  2. 显示AHT20的温度和湿度;

  3. 滑动显示长字符。

冲冲冲!


一、实验涉及相关知识的学习与理解

做该实验我们需要学习如下知识:

1、OLED

OLED显示屏是利用有机电自发光二极管制成的显示屏。由于同时具备自发光有机电激发光二极管,不需背光源、对比度高、厚度薄、视角广、反应速度快、可用于挠曲性面板、使用温度范围广、构造及制程较简单等优异之特性,被认为是下一代的平面显示器新兴应用技术。

我们使用的OLED屏如下图:
基于SPI/IIC接口的OLED数据显示
基于SPI/IIC接口的OLED数据显示
我们的是0.96寸IIC 4针 GND开头中文wiki:
基于SPI/IIC接口的OLED数据显示
基于SPI/IIC接口的OLED数据显示
基于SPI/IIC接口的OLED数据显示
相关资料连接:链接: link.
基于SPI/IIC接口的OLED数据显示
下载好后打开相关工程:
基于SPI/IIC接口的OLED数据显示

基于SPI/IIC接口的OLED数据显示

2、汉字点阵编码原理

汉字编码

** 区位码**
在国标GD2312—80中规定,所有的国标汉字及符号分配在一个94行、94列的方阵中,方阵的每一行称为一个“区”,编号为01区到94区,每一列称为一个“位”,编号为01位到94位,方阵中的每一个汉字和符号所在的区号和位号组合在一起形成的四个阿拉伯数字就是它们的“区位码”。区位码的前两位是它的区号,后两位是它的位号。用区位码就可以唯一地确定一个汉字或符号,反过来说,任何一个汉字或符号也都对应着一个唯一的区位码。汉字“母”字的区位码是3624,表明它在方阵的36区24位,问号“?”的区位码为0331,则它在03区3l位。

机内码
汉字的机内码是指在计算机中表示一个汉字的编码。机内码与区位码稍有区别。如上所述,汉字区位码的区码和位码的取值均在1–94之间,如直接用区位码作为机内码,就会与基本ASCII码混淆。为了避免机内码与基本ASCII码的冲突,需要避开基本ASCII码中的控制码(00H–1FH),还需与基本ASCII码中的字符相区别。为了实现这两点,可以先在区码和位码分别加上20H,在此基础上再加80H(此处“H”表示前两位数字为十六进制数)。经过这些处理,用机内码表示一个汉字需要占两个字节,分别 称为高位字节和低位字节,这两位字节的机内码按如下规则表示: 高位字节 = 区码 + 20H + 80H(或区码 + A0H) 低位字节 = 位码 + 20H + 80H(或位码 + AOH) 由于汉字的区码与位码的取值范围的十六进制数均为01H–5EH(即十进制的01–94),所以汉字的高位字节与低位字节的取值范围则为A1H–FEH(即十进制的161–254)。 例如,汉字“啊”的区位码为1601,区码和位码分别用十六进制表示即为1001H,它的机内码的高位字节为B0H,低位字节为A1H,机内码就是B0A1H。

关于点阵字库结构

点阵字库存储
在汉字的点阵字库中,每个字节的每个位都代表一个汉字的一个点,每个汉字都是由一个矩形的点阵组成,0代表没有,1代表有点,将0和1分别用不同颜色画出,就形成了一个汉字,常用的点阵矩阵有 1212, 1414, 1616三种字库。 字库根据字节所表示点的不同有分为横向矩阵和纵向矩阵,目前多数的字库都是横向矩阵的存储方式(用得最多的应该是早期UCDOS字库),纵向矩阵一般是因为有某些液晶是采用纵向扫描显示法,为了提高显示速度,于是便把字库矩阵做成纵向,省得在显示时还要做矩阵转换。我们接下去所描述的都是指横向矩阵字库。
**16
16点阵字库**
我们用得多的是16x16,对于16x16的矩阵来说,它所需要的位数共是16*16=256个位,每个字节为8位,因此,每个汉字都需要用256/8=32个字节来表示。 即每两个字节代表一行的16个点,共需要16行,显示汉字时,只需一次性读取32个字节,并将每两个字节为一行打印出来,即可形成一个汉字。

3、字模软件

我们使用的是之前实验下载的野火相关资料里包含的字模软件
基于SPI/IIC接口的OLED数据显示
基于SPI/IIC接口的OLED数据显示
看清楚字宽和字高哦,我这里用的是16X16的。下面生成的就是我们需要的字的点阵。

二、开始实验

准备工作完成,进行实物连接,工程里有如下连接:
基于SPI/IIC接口的OLED数据显示
基于SPI/IIC接口的OLED数据显示
对工程进行一些改动,把mian.c函数只保留如下函数,其余全部注销掉

TEST_Chinese();          //中文显示测试
OLED_Clear(0)

改改test.c里的

void TEST_Chinese(void)
{	
	GUI_ShowString(45,0,"631807030233",8,1);
	GUI_ShowCHinese(16,20,16,"意意",1);
}

打开指南者资料中开发软件的字模生成软件PCtoLCD2002,记得要把字旋转成这样(镜像+逆时针转动),不然出来的字会是反的。
基于SPI/IIC接口的OLED数据显示
打开下载的OLED资料中HARDWARE,找到OLED文件,用记事本方式打开ioedfont文本。
基于SPI/IIC接口的OLED数据显示
开改!
基于SPI/IIC接口的OLED数据显示
这个位置贴进去
基于SPI/IIC接口的OLED数据显示
上面是除开名字其他增添的内容,形成也是通过字模软件构成。
烧录进去,就形成了如下
基于SPI/IIC接口的OLED数据显示

然后我们之前做过AHT20的温度和湿度相关实验嘛,把上次用的中使用过的bsp_i2c.c、bsp_i2c.h、usart.c、usart…h文件添加到这次的工程的USER文件夹。相关博客连接

链接: link
实现滑动修改如下代码,下面这个是加到主函数main.c的while循环里

GUI_ShowCHinese(20,25,16,"»¶Ó­À´µ½ÖØÇ콻ͨ´óѧ",1);
delay_ms(50);
roll();

这个oled.c是改在末尾:

//硬件滚动
void roll(void)
{  
	OLED_WR_Byte(0x2F, OLED_CMD);  
	OLED_WR_Byte(0x27, OLED_CMD);   
	OLED_WR_Byte(0x00,OLED_CMD);       
  	OLED_WR_Byte(0x00,OLED_CMD);        
  	OLED_WR_Byte(0x07,OLED_CMD);        
  	OLED_WR_Byte(0x2E,OLED_CMD); 	
  	while(1);
}

再烧进去!冲!
基于SPI/IIC接口的OLED数据显示
芜湖起飞!实验成功

总结

本次实验室在上次实验的基础上进行了扩张,实现了目标功能,也发现自己应该多在目标代码里观察连线。因为瞎连线还出了点问题。

本文地址:https://blog.csdn.net/qq_44719839/article/details/111866676