使用51单片机和MAX7219控制点阵滚动显示

最近玩MAX7129控制点阵,弄了一个用51和MAX7219控制两个1088AS点阵滚动显示。此文章作为总结。方便自己日后需要时回顾,也方便他人借鉴参考。文中如果有地方不准确,有错误,欢迎指正。
这次主要用了一个STC89C52RC、两个MAX7219和两个1088AS8*8点阵。
刚开始做了好几天没弄出来,最后发现是硬件出了问题……弄好硬件后很快就做了出来。下面主要是在整个过程中一些探索

1088AS

因为之前没找到相关资料,所以自己一个一个引脚测了一下,第一张图是自己测的各引脚控制的行或列以及是接GND还是VCC,右侧
是标有1088AS和突出一个半圆的一侧。第二张厂家公司提供的,他这个排列方式……反正我是有点懵。在这里插入图片描述在这里插入图片描述

MAX7219

芯片的各个引脚
在这里插入图片描述
芯片的各个引脚作用以及典型应用电路可以从芯片手册中了解。注意DIG-\SEG+。

程序

这个直接附上,也不难。

#include <reg52.h>
//宏定义
#define uchar unsigned char
#define uint  unsigned int
//定义MAX7219与单片机的连接引脚
sbit CLK  = P1^0;//时钟序列输入端
sbit CS = P1^1;//载入数据端
sbit DIN  = P1^2;//串行数据输入端
//Hello World数组
uchar code array[]={
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x7E,0x10,0x7E,0x00,0x7C,0x54,0x5C,0x00,
0x7E,0x40,0x00,0x7E,0x40,0x00,0x38,0x44,0x38,0x00,0x3E,0x40,0x38,0x40,0x3E,0x00,
0x38,0x44,0x38,0x00,0x7C,0x08,0x04,0x00,0x7E,0x40,0x00,0x70,0x50,0x7E,0x00,0x00,
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00
//hello world!
};
//延时函数
void Delay_xms(uint x)
{
	uint i,j;
	for(i=0;i<x;i++)
	{
		for(j=0;j<112;j++);
	}
}
//向MAX7219写入字节
void write_MAX7219_byte(uchar DATA)
{
	uchar i;
	CS = 0;
	for(i=8;i>=1;i--)
	{
		CLK = 0;
		DIN = DATA&0x80;
		DATA=DATA<<1;
		CLK = 1;
	}
}	
//向第一个MAX7219写入数据
void write_MAX7219_1(uchar address,uchar dat)
{
	CS = 0;
	write_MAX7219_byte(address);
	write_MAX7219_byte(dat);
	CS = 1;
}
//向第二个MAX7219写入数据
void write_MAX7219_2(uchar address,uchar dat)
{
	CS = 0;
	write_MAX7219_byte(address);
	write_MAX7219_byte(dat);
	CLK = 1;
	write_MAX7219_byte(0x00);
	write_MAX7219_byte(0x00);
	CS = 1;
}
//设置MAX7219
void Init_MAX7219()
{
	write_MAX7219_1(0x09,0x00);
	write_MAX7219_1(0x0A,0x03);
	write_MAX7219_1(0x0B,0x07);
	write_MAX7219_1(0x0C,0x01);
	write_MAX7219_1(0x0F,0x00);
	
	write_MAX7219_2(0x09,0x00);
	write_MAX7219_2(0x0A,0x03);
	write_MAX7219_2(0x0B,0x07);
	write_MAX7219_2(0x0C,0x01);
	write_MAX7219_2(0x0F,0x00);
}

void main()
{
	uchar i,j;
	Delay_xms(50);
	Init_MAX7219();
	while(1)
	{
		for(j=0;j<=40;j++)
		{
			for(i=1;i<9;i++)
			{
				write_MAX7219_1(i,array[j+i-1]);
				write_MAX7219_2(i,array[8+j+i-1]);
			}
			Delay_xms(500);
		}
	}
}

字的取模

取模我用的字是“hello world”,这个刚开始学习51时取模方法不同,这个不需要黑白反显。下图是我的点阵两个都是有半圆的一边朝右,所以取模时,先设定的是高8宽48,就是横着一行字,然后顺时针旋转九十度再左右调转,取出来就可以了
在这里插入图片描述

调试

调的地方就是
这行里面的array[8+j+i-1]里的8

write_MAX7219_2(i,array[8+j+i-1]);

刚开始想当然的弄了个9,后来发现好像不对,然后在写入数据后面加了个延时,延长了他在切换列时的间隔,发现第二个点阵比设想中的快了一个,然后将9改成了8

for(i=1;i<9;i++)
			{
				write_MAX7219_1(i,array[j+i-1]);
				write_MAX7219_2(i,array[8+j+i-1]);
				Delay_xms(150);
			}
  • 21
    点赞
  • 94
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
MAX7219是一种常用的点阵LED驱动芯片,可以控制8x8的点阵LED灯组成的字符或图形进行显示。在51单片机使用MAX7219进行点阵动态显示,需要先编写驱动程序,然后通过串口或者其他输入设备来输入要显示的字符或图形。 以下是一个简单的MAX7219点阵动态显示的程序框架: ```c #include <reg51.h> #include <intrins.h> // MAX7219控制端口定义 sbit MAX7219_CS = P1^0; sbit MAX7219_CLK = P1^1; sbit MAX7219_DIN = P1^2; // MAX7219控制函数 void MAX7219_SendByte(unsigned char data) { unsigned char i; for (i = 8; i > 0; i--) { MAX7219_CLK = 0; // 时钟线拉低 MAX7219_DIN = data & 0x80; // 数据线输出最高位,即先传输高位 data <<= 1; // 数据左移一位,准备传输下一位 MAX7219_CLK = 1; // 时钟线拉高 } } // MAX7219初始化函数 void MAX7219_Init(void) { MAX7219_CS = 1; // 片选线拉高 MAX7219_SendByte(0x0C); // 打开显示,亮度默认 MAX7219_SendByte(0x01); // 显示测试,所有LED点亮 MAX7219_SendByte(0x0F); // 关闭显示,亮度最大 } // 显示字符函数,例如显示字符A void MAX7219_ShowChar(unsigned char row, unsigned char col, unsigned char ch) { unsigned char i; MAX7219_CS = 0; // 片选线拉低 MAX7219_SendByte(col + 1); // 选择列地址 MAX7219_SendByte(ch); // 显示字符 MAX7219_CS = 1; // 片选线拉高 } // 主函数 void main(void) { MAX7219_Init(); // MAX7219初始化 while (1) { // 读取输入字符或图形 // 进行动态显示 } } ``` 在主函数中,可以通过读取输入字符或图形的方式来进行动态显示。例如,可以通过串口发送字符数据,然后在主函数中读取串口接收缓冲区的数据,并将其转换成MAX7219可以显示的格式。然后通过MAX7219_ShowChar函数来进行显示。 需要注意的是,MAX7219控制方式非常严格,需要按照其规定的时序和数据格式进行控制。因此,在编写MAX7219驱动程序时,需要仔细参考其数据手册,确保控制方式的正确性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值