51单片机8×8点阵屏设计(51单片机led光立方)

1.简介本设计是以STC89C52单片机的8x8x8的LED光立方。本设计将LED光立方分成8层,分别由单片机的P1,8个IO口来控制每一层,由于采用的是共阴极所以当层电位为高电平有效,由P0口和P2的总共16个IO口来控制每层的64盏灯,低电平有效,P2口通过8个74HC573缓冲器芯片来驱动LED。这样就可以通过控制IO口的输出电平来控制每盏灯的亮灭。2.硬件设计本系统的硬件电路主要单片…

大家好,又见面了,我是你们的朋友全栈君。

1.简介
设计是以STC89C52单片机的8x8x8的LED光立方。本设计将LED光立方分成8层,分别由单片机的P1,8个IO口来控制每一层,由于采用的是共阴极所以当层电位为高电平有效,由P0口和P2的总共16个IO口来控制每层的64盏灯,低电平有效,P2口通过8个74HC573缓冲器芯片来驱动LED。这样就可以通过控制IO口的输出电平来控制每盏灯的亮灭。

2.硬件设计
本系统的硬件电路主要单片机最小系统、LED光立方驱动电路、LED光立方电路组成,其硬件框图如图:
在这里插入图片描述
(1)光立方驱动电路原理
以8X8X8光立方为例:

一个光立方我们可以拆成8个面,如图
在这里插入图片描述
而每个面又有8X8共64个LED灯,如图:
在这里插入图片描述
这样,我们只要控制这 64 个灯使其能够自由变换,然后再通过控制每个层依次点亮即可,由于我们眼睛的视觉暂留,使我们感觉看到的东西是一起再亮的。这样我们就看到了一个完整的个体。
驱动的步骤是:

  1. Z轴选中一个要点亮的面(一个面共有8段Y轴)
  2. Y轴选中一个需要点亮的Y轴(一段Y轴共有8个LED灯)
  3. X轴上的8个控制引脚通过设定的编码来点亮8个LED中某几个,并延时相应的时间
  4. 重复扫描8个Y轴边完成一个面的点亮,然后再重复扫描其他7个面,便完成了一次光立方的点亮了

(2)光立方驱动电路设计
此光立方采用一个ULN2308驱动芯片(作为Z轴的选择),和8个8路的74HC573锁存器(一个74HC573作为一个Y轴)来驱动8X8X8共512个LED灯。整体电路如图:
在这里插入图片描述
总的原理是每一时刻选中573的LE使能脚,使其为低电平,再由573输送次引脚对应的8个LED的亮灭状态,一个阴极点需要8位,即一个字节数据,完成一次完整的显示需要64个字节,此为一帧,要产生动画效果则需要产生中断进入下一帧。

(3)总体硬件电路
在这里插入图片描述
3.软件设计
(1)软件说明
光立方的软件设计相对简单,主要根据相应的动画效果的编码对光立方进行动态扫描,软件流程如图:
在这里插入图片描述
程序开始运行,获取到要显示的LED所在的层和列然后调用显示子程序点亮LED灯,通过延时程序进行短暂延时后继续获取下一个要显示的LED灯的所在的层和列。
如果你想要设计自己所要的动画效果,可以通过常用的光立方取模软件获得相应的动画编码。

(2)部分显示效果编码

uchar code display[]={
						
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x00,0x18,0x18,0x00,0x00,0x00,	    //1
					 0x00,0x00,0x00,0x18,0x18,0x00,0x00,0x00,	   
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,

					0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x3c,0x24,0x24,0x3c,0x00,0x00,
					 0x00,0x00,0x24,0x00,0x00,0x24,0x00,0x00,	    //2
					 0x00,0x00,0x24,0x00,0x00,0x24,0x00,0x00,
					 0x00,0x00,0x3c,0x24,0x24,0x3c,0x00,0x00,
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					............
					0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x00,0x18,0x18,0x00,0x00,0x00,	    //骰子1-49
					 0x00,0x00,0x00,0x18,0x18,0x00,0x00,0x00,	   
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
					 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,}					 

(3)主函数代码

void main()
{
	init();	
	while(1)
	{
		for(i=0;i<8;i++)
		{
			Z = Z_Seg[i];
			for(j=0;j<8;j++)
				{
					Y = Y_Seg[j];
					X = display[count++];
					delay();
				}
			}
		count=64*temp;	
	}
}

源码+AD原理图 下载:关注公众号,首页回复“光立方”获取资料
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/127533.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Spring cloud 1 – Eurake的服务搭建[通俗易懂]

    Spring cloud 1 – Eurake的服务搭建[通俗易懂]相当于搭建zookeeper、但是springclould推荐使用Eurake作为注册中心,相比zookeeper不需要下载zookeeper1.创建一个空的maven项目,并且依赖jar&amp;lt;parent&amp;gt;&amp;lt;groupId&amp;gt;org.springframework.boot&amp;lt;/groupId&amp;gt;&amp;lt;artifactId&a

    2022年6月8日
    28
  • MySQL字段存储的内容是不区分大小写的,你知道吗?

    做一个积极的人编码、改bug、提升自己我有一个乐园,面向编程,春暖花开!分享一下大神老师的人工智能教程。零基础!通俗易懂!风趣幽默(偶尔开开车,讲讲黄段子)!大家可以看看是否对自己有帮助,如果你对人工智能感兴趣,希望你也加入到我们人工智能的队伍中来,点击这里查看【人工智能教程】。接下来进入正文。文章目录00 简单回顾01 一个例子02 解决方案03 总结04 参考资料00 简单回…

    2022年2月28日
    38
  • PHPer面试指南-MySQL 篇[通俗易懂]

    PHPer面试指南-MySQL 篇

    2022年2月11日
    37
  • jenkins allure_Jenkins

    jenkins allure_Jenkins前言jenkins集成了allure插件,安装插件后运行pytest+allure的脚本即可在jenkins上查看allure报告了。allure安装在运行代码的服务器本机,我这里是用的dock

    2022年7月31日
    4
  • JSON三种数据解析方法「建议收藏」

    JSON三种数据解析方法「建议收藏」引言JSON数据现在是我们开发中用的最多的,百分之八十的数据都是通过JSON方式进行传输,那么想要学好JSON解析就要了解什么是JSON数据,怎么快速解析它从而提升开发效率。

    2022年6月6日
    116
  • 单调栈算法详解_单调栈和单调队列

    单调栈算法详解_单调栈和单调队列单调栈算法详解单调栈使用模板stack<int>st;//此处一般需要给数组最后添加结束标志符,具体下面例题会有详细讲解for(遍历这个数组){if(栈空||栈顶元素大于等于当前比较元素){入栈;}else{while(栈不为空&&栈顶元素小于当前元素){栈顶元素出栈;更新结果;}入栈;}}或者简化

    2022年9月22日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号