LED点阵屏(基于51单片机)

师从江科大  

LED点阵屏

LED点阵屏由若干个独立的LED组成,LED以矩阵的形式排列,以灯珠亮灭来显示文字、图片、视频等。

LED点阵屏分类

按颜色:单色、双色、全彩

按像素:8*8、16*16等(大规模的LED点阵通常由很多个小点阵拼接而成)

注:开发版上的就是8*8的单色点阵

显示原理

 1、LED点阵屏的结构类似于数码管,只不过是数码管把每一列的像素以“8”字型排列而已

2、LED点阵屏与数码管一样,有公阴和公阳两种接法,不同接法对应的电路结构不同

3、LED点阵屏需要进行逐行或逐列扫描,才能使LED同时显示

开发板引脚对应关系

 

 74HC5959(串行输入并行输出寄存器)

可用3根线输入串行数据,8根线输出并行数据,多片级联后,可输出16位,24位,32位等多用于IO口的扩展

1、OE(output enable):输出使能

2、RCLK(register clock)寄存器时钟:

3、SRCLR(Shift Register Clear)串型清零端:这个引脚的作用是用来对内部移位寄存器进行复位操作。当SRCLR引脚接收到一个有效的低电平信号时,它会将整个8位移位寄存器中的数据清零,所有位都会被置为逻辑0。这意味着无论之前通过串行输入(SER)端口送入了什么数据,一旦SRCLR被拉低并有效,该芯片的移位寄存器内容将立即清除。

此外,需要注意的是,SRCLR并不直接影响存储寄存器和输出寄存器的内容,但通常情况下,当移位寄存器被清零后,在下一个RCLK上升沿到来时,由于移位寄存器内已经没有有效数据,输出寄存器也会更新为空,从而导致所有输出引脚都变为低电平状态(假设输出负载为高阻态)。

SERCLK(串行时钟)    SER(串行输入端)  QH:用来多片级联

实现串行输入并行输出的方法

首先,SER给移位寄存器输入串行数据,SERCLK(串行时钟)每提供一个上升沿,数据就向下走一位,走完之后,如果RCLK(寄存器时钟  )有上升沿,RCLK就会把移位寄存器中的8位数据同时搬运到图中右边8个区,就达到了实现串行输入并行输出的目的(如果数据满了,数据就会从QH处输出到下一片的SER)

C51的sfr、sbit

sfr(special function register):特殊功能寄存器声明

例:sfr P0=0x80;

sbit (special bit): 特殊位声明

例:sbit P0_1=ox81;或sbit P0_1=P0^1

声明P0寄存器的第一位

LED点阵显示图形代码(显示笑脸)

#include <REGX52.H>
#include "Delay.h"sbit SER=P3^4;			//SER串行数据位,P3^4用于I/O口被定义,P3_4用于定义I/O口
sbit RCK=P3^5;			//RCLK寄存器时钟位,名字重复,改成RCK
sbit SCK=P3^6;			//SRCLK串行时钟,简便成SCK#define Matrix_LED_Port		P0		//定义Matrix_LED_Port(LED矩阵屏端口)为P0口/*** @brief  74HC595写入一个字节* @param  Byte写入的字节* @retval 无*/
void _74HC595_WriteByte(unsigned char Byte)//对八个引脚赋值
{unsigned char i;for(i=0;i<8;i++)//把它的八位都移出去{SER=Byte&(0x80>>i);	//1000 0000,每次循环,1往右移一位//Byte第8位为1,则结果为0x80,Byte第8位为0,则结果为0//将一个8位数据赋值给一位值时//非0即1,只有Byte&0x80为0,SER才为0,其他数时,SER都是1SCK=1;				//每一个上升沿,就会将SER输入的数据在寄存器中下移一位SCK=0;}RCK=1;					//8位数据都输入完成后,给RCK一个上升沿,就会将8位数据送入I/O口RCK=0;
}/*** @brief  LED点阵屏显示一列数据* @param  Column 要选择的列,范围:0~7,第0列在最左边* @param  Data 选择列所显示的数据,高位在上,1为亮,0为灭* @retval 无*/
void MatrixLED_ShowColumn(unsigned char Column,Data)
{_74HC595_WriteByte(Data);				//位选,数据通过74HC595寄存器,哪一位为1,则哪一行的LED就亮Matrix_LED_Port=~(0x80>>Column);		//段选,P0哪一位为0,则LED矩阵屏哪一列就亮	//LED矩阵屏第Column列亮Delay(1);Matrix_LED_Port=0xFF;					//消影,段选位选完后,将段选清零
}void main()
{SCK=0;RCK=0;//初始化为低电平while(1){MatrixLED_ShowColumn(0,0x3C);			//在LED矩阵屏上显示一个笑脸MatrixLED_ShowColumn(1,0x42);	MatrixLED_ShowColumn(2,0xA9);	MatrixLED_ShowColumn(3,0x85);MatrixLED_ShowColumn(4,0x85);	MatrixLED_ShowColumn(5,0xA9);	MatrixLED_ShowColumn(6,0x42);	MatrixLED_ShowColumn(7,0x3C);	}
}
/*
sfr(special function register):特殊功能寄存器声明
例:sfr P0=0x80;
sbit(special bit):特殊位声明
例:sbit P0_1=0x80;
*/

 还有Delay.c和Delay.h文件

LED点阵显示动画代码(笑脸变哭脸)

main.c

#include <REGX52.H>
#include "Delay.h"
#include "MatrixLED.h"
//流动式动画代码
/*unsigned char Animation[]={0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xFF,0x08,0x08,0x08,0xFF,0x00,0x0E,0x15,0x15,0x15,0x08,0x00,0x7E,0x01,0x02,0x00,0x7E,0x01,0x02,0x00,0x0E,0x11,0x11,0x0E,0x00,0x7D,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
};void main()
{unsigned char i,offset=3,Count=0;MatrixLED_Init();while(1){for(i=0;i<8;i++){MatrixLED_ShowColumn(i,Animation[i+offset]);	}Count++;if(Count>10){Count=0;offset++;if(offset>40){offset=0;}}}
}*/
/*
sfr(special function register):特殊功能寄存器声明
例:sfr P0=0x80;
sbit(special bit):特殊位声明
例:sbit P0_1=0x80;
*/
//逐帧动画代码   
unsigned char code Animation[]={0x3C,0x42,0xA9,0x85,0x85,0xA9,0x42,0x3C,0x3C,0x42,0xA1,0x85,0x85,0xA1,0x42,0x3C,0x3C,0x42,0xA5,0x89,0x89,0xA5,0x42,0x3C,	
};//加了code不能更改  从储存在RAM变到flash中 使RAM的空间腾出来运行更多的数据void main()
{unsigned char i,offset=0,Count=0;MatrixLED_Init();while(1){for(i=0;i<8;i++){MatrixLED_ShowColumn(i,Animation[i+offset]);	}Count++;if(Count>20){Count=0;offset+=8;//主要区别if(offset>16){offset=0;}}}
}

MATRIXLED.c

#include <REGX52.H>
#include "Delay.h"sbit SER=P3^4;			//SER串行数据位,P3^4用于I/O口被定义,P3_4用于定义I/O口
sbit RCK=P3^5;			//RCLK寄存器时钟位,名字重复,改成RCK
sbit SCK=P3^6;			//SRCLK串行时钟,简便成SCK#define MATRIX_LED_PORT		P0		//定义Matrix_LED_Port(LED矩阵屏端口)为P0口/*** @brief  74HC595写入一个字节* @param  Byte写入的字节* @retval 无*/
void _74HC595_WriteByte(unsigned char Byte)//对八个引脚赋值
{unsigned char i;for(i=0;i<8;i++)//把它的八位都移出去{SER=Byte&(0x80>>i);	//1000 0000,每次循环,1往右移一位//Byte第8位为1,则结果为0x80,Byte第8位为0,则结果为0//将一个8位数据赋值给一位值时//非0即1,只有Byte&0x80为0,SER才为0,其他数时,SER都是1SCK=1;				//每一个上升沿,就会将SER输入的数据在寄存器中下移一位SCK=0;}RCK=1;					//8位数据都输入完成后,给RCK一个上升沿,就会将8位数据送入I/O口RCK=0;
}
/*** @brief  点阵屏初始化* @param  无* @retval 无*/
void MatrixLED_Init()
{SCK=0;RCK=0;
}
/*** @brief  LED点阵屏显示一列数据* @param  Column 要选择的列,范围:0~7,第0列在最左边* @param  Data 选择列所显示的数据,高位在上,1为亮,0为灭* @retval 无*/
void MatrixLED_ShowColumn(unsigned char Column,Data)
{_74HC595_WriteByte(Data);				//位选,数据通过74HC595寄存器,哪一位为1,则哪一行的LED就亮MATRIX_LED_PORT=~(0x80>>Column);		//段选,P0哪一位为0,则LED矩阵屏哪一列就亮	//LED矩阵屏第Column列亮Delay(1);MATRIX_LED_PORT=0xFF;					//消影,段选位选完后,将段选清零
}

MATRIXLED.h

#ifndef __MATRIX_LED_H__
#define __MATRIX_LED_H__void MatrixLED_Init();
void MatrixLED_ShowColumn(unsigned char Column,Data);#endif

还有Delay.c和Delay.h文件

LED点阵屏显示流动式动画(I love you )

#include <REGX52.H>
#include "MatrixLED.h"//动画数据
unsigned char Date[]={0X00,0X00,0X00,0X00,0X00,0x21,0x3f,0x21,     //I0x00,0x18,0x24,0x22,0x11,0x22,0x24,0x18,//爱心0x00,0x3f,0x01,0x01,0x3f, //u0X00,0X00,0X00,0X00,0X00,};void main()
{unsigned char i,Offset=0,Count=0;//偏移量OffsetMatrixLED_Init(); //初始化while(1){for(i=0;i<8;i++)	{MatrixLED_ShowColumn(i,Date[i+Offset]);}Count++;			if(Count>40) //计次延时{Count=0;Offset+=1;		if(Offset>18)//当超过数组的范围时偏移量清零{Offset=0;}}}
}

若有侵权,请联系作者

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/664821.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL原理(三)锁定机制(2)表锁行锁与页锁

前面提到&#xff0c;mysql锁按照操作颗粒分类&#xff0c;一般认为有表级锁、行级锁、页面锁三种。其实还有一种特殊的全局锁。 锁场景问题全局锁全库逻辑备份加了全局锁之后&#xff0c;整个数据库都是【只读状态】&#xff0c;如果数据库里有很多数据&#xff0c;备份就会花…

BUUCTF-Real-ThinkPHP]5.0.23-Rce

漏洞介绍 这个版本容易存在我们都喜欢的rce漏洞&#xff01; 网站为了提高访问效率往往会将用户访问过的页面存入缓存来减少开销。而Thinkphp 在使用缓存的时候是将数据序列化&#xff0c;然后存进一个 php 文件中&#xff0c;这使得命令执行等行为成为可能&#xff01; ThinkP…

Springboot 自定义参数配置化,密钥,密码,文件保存路径

application.properties 和 application.yml 都是一样的配置方法&#xff0c;只是格式不一样 定义配置文件 server.port8080 image.save.pathE:\ #自定义文件保存路径读取配置文件 Value("${image.save.path}")private String filePath;//E:\优化配置文件 如果我参…

HashMap的扩容机制

HashMap简介 HashMap在底层数据结构上采用了数组&#xff0b;链表&#xff0b;红黑树&#xff0c;通过散列映射来存储键值对数据因为在查询上使用散列码&#xff08;通过键生成一个数字作为数组下标&#xff0c;这个数字就是hash code&#xff09;所以在查询上的访问速度比较快…

备战蓝桥杯---搜索(DFS基础1)

何为深搜&#xff1f; 即不撞南墙不罢休。 话不多说&#xff0c;直接看题&#xff1a; 我们可以把这看成深搜的模板题&#xff0c;下面是AC代码&#xff1a; #include<bits/stdc.h> using namespace std; int a[15];//存值并输出 int vis[15]; int n18; void dfs(int …

Redisson看门狗机制

一、背景 网上redis分布式锁的工具方法&#xff0c;大都满足互斥、防止死锁的特性&#xff0c;有些工具方法会满足可重入特性。如果只满足上述3种特性会有哪些隐患呢&#xff1f;redis分布式锁无法自动续期&#xff0c;比如&#xff0c;一个锁设置了1分钟超时释放&#xff0c;…

YOLOv5白皮书-第Y3周:yolov5s.yaml文件解读

YOLOv5白皮书-第Y3周:yolov5s.yaml文件解读 YOLOv5白皮书-第Y3周:yolov5s.yaml文件解读一、前言二、我的环境三、yolov5s.yaml源文件内容四、Parameters五、anchors配置六、backbone七、head八、总结 OLOv5-第Y2周&#xff1a;训练自己的数据集) YOLOv5白皮书-第Y3周:yolov5s.…

从MySQL到TiDB:兼容性全解析

MySQL 在高并发和大数据量场景下&#xff0c;单个实例的扩展性有限。而 TiDB 作为一款分布式NewSQL数据库&#xff0c;设计之初就支持水平扩展&#xff08;Scale-Out&#xff09;&#xff0c;通过增加节点来线性提升处理能力和存储容量&#xff0c;能够很好地应对大规模数据和高…

机器学习——绪论总结

目录 一、引入 二、基本术语 三、假设空间与归纳偏 四、模型选择 一、引入 机器学习&#xff1a;通过计算手段&#xff0c;得出具有能够自我修改、完善能力的模型&#xff0c;利用经验改善系统自身性能。算法使用数据得到模型的过程即称为学习&#xff0c;或训练 流程&…

Framework - ActivityThread 应用启动UI渲染流程

一、概念 ActivityThread拥有 main(String[] agrs) 方法&#xff0c;作为程序的入口&#xff0c;是应用程序的初始化类。&#xff08;ActivityThread不是主线程&#xff0c;它在 main() 方法中实例化&#xff0c;是运行在主线程中。&#xff09;ApplicationThread是 ActivityT…

【Nginx】Ubuntu如何安装使用Nginx反向代理?

文章目录 使用Nginx反向代理2个web接口服务步骤 1&#xff1a;安装 Nginx步骤 2&#xff1a;启动 Nginx 服务步骤 3&#xff1a;配置 Nginx步骤 4&#xff1a;启用配置步骤 5&#xff1a;检查配置步骤 6&#xff1a;重启 Nginx步骤 7&#xff1a;访问网站 proxy_set_header 含义…

海外IP代理:解锁网络边界的实战利器

文章目录 引言&#xff1a;正文&#xff1a;一、Roxlabs全球IP代理服务概览特点&#xff1a;覆盖范围&#xff1a;住宅IP真实性&#xff1a;性价比&#xff1a;在网络数据采集中的重要性&#xff1a; 二、实战应用案例一&#xff1a;跨境电商竞品分析步骤介绍&#xff1a;代码示…

LeetCode--189

189. 轮转数组 提示 给定一个整数数组 nums&#xff0c;将数组中的元素向右轮转 k 个位置&#xff0c;其中 k 是非负数。 示例 1: 输入: nums [1,2,3,4,5,6,7], k 3 输出: [5,6,7,1,2,3,4] 解释: 向右轮转 1 步: [7,1,2,3,4,5,6] 向右轮转 2 步: [6,7,1,2,3,4,5] 向右轮转…

Ingress

文章目录 环境准备什么是 Ingress认识 Ingress 资源Ingress 控制器(controller)Ingress 规则pathType 路径类型多重匹配Ingress 类TLS生成证书创建密钥 环境准备 下面的 yaml 文件内容&#xff0c;是使用 sts 创建两个 web 服务&#xff0c;并配置对应的 servcie。web 服务的首…

微信小程序(三十三)promise异步写法

注释很详细&#xff0c;直接上代码 上一篇 新增内容&#xff1a; 1.promise异步与普通异步的写法区别 2.promise异步的优势 源码&#xff1a; index.wxml <view class"preview" bind:tap"onChoose"><image src"{{avatar}}" mode"…

网络时间协议NTP工作模式

单播服务器/客户端模式 单播服务器/客户端模式运行在同步子网中层数较高层上。这种模式下,需要预先知道服务器的IP地址。 客户端:运行在客户端模式的主机(简称客户端)定期向服务器端发送报文,报文中的Mode字段设置为3(客户端模式)。当客户端接收到应答报文时,客户端会…

Chapter One - The History of Computers

Chapter One - The History of Computers 第一章 - 计算机的历史 I. Reading Material I. 阅读材料 My friends, let’s embark on an enlightening journey through the captivating history of computers, unraveling the intricate threads that have woven the technolog…

DockerCompose+SpringBoot+Nginx+Mysql实践

DockerComposeSpringBootNginxMysql实践 1、Spring Boot案例 首先我们先准备一个 Spring Boot 使用 Mysql 的小场景&#xff0c;我们做这样一个示例&#xff0c;使用 Spring Boot 做一个 Web 应 用&#xff0c;提供一个按照 IP 地址统计访问次数的方法&#xff0c;每次请求时…

linux交叉编译方法——虚拟机编译,在树莓派平台上运行

一、 交叉编译是什么 交叉编译 是在一个平台上生成另一个平台上的可执行代码。 我们再windows上面编写C51代码&#xff0c;并编译成可执行代码&#xff0c;如xx.hex, 是在c51上面运行&#xff0c;不是在windows上面运行 我们在ubuntu上面编写树…

Kubernetes k8s

Kubernetes k8s 一个开源的容器编排引擎&#xff0c;用来对容器化应用进行自动化部署、 扩缩和管理。 从架构设计层面&#xff0c;k8s能很好的解决可用性&#xff0c;伸缩性&#xff1b;从部署运维层面&#xff0c;服务部署&#xff0c;服务监控&#xff0c;应用扩容和故障处…