- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
LED点阵实验
8*8LED点阵实验
实验目的:
掌握LED点阵实验原理,并能熟练操作,编程实现点阵循环显示数字0~9;
二、实验器件:
单片机AT89S52最小实验系统,74LS138,74LS595,导线若干;
三、实验原理:
1、芯片简介:
74LS138 为3 线-8 线译码器原理:当一个选通端(G1)为高电平,另两个选通端(/(G2A)和/(G2B))为低电平时,可将地址端(A、B、C)的二进制编码在一个对应的输出端以低电平译出QA--QH: 八位并行输出端。
QH: 级联输出端。接下一个595的SI端。
SI: 串行数据输入端。
74595的控制端说明:
/SRCLR(10脚): 低点平时将移位寄存器的数据清零。通常将它接Vcc。
SRCK(11脚):上升沿时数据寄存器的数据移位。QA--QB--QC--...--QH;下降沿移位寄存器数据不变。RCK(12脚):上升沿时移位寄存器的数据进入数据存储寄存器,下降沿时存储寄存器数据不变。当移位结束后,在RCK端产生一个正脉冲(5V时,大于几十纳秒就行了通常都选微秒级),更新显示数据。
/G(13脚): 高电平时禁止输出(高阻态)。如果单片机的引脚不紧张,用一个引脚控制它,可以方便地产生闪烁和熄灭效果。比通过数据端移位控制要省时省力。#includeintrins.h
#define uchar unsigned char //宏定义
#define uint unsigned int
sbit SCK=P0^0; //芯片端口连线定义
sbit RCK=P0^1;
sbit SER=P0^2;
sbit D138_A=P0^5;
sbit D138_B=P0^6;
sbit D138_C=P0^7;
uchar code hang[8]={1,2,3,4,5,6,7,8}; //点阵行数组定义
uchar code lie[10][8]={ //数字0~9列代码
{0x00,0x7c,0x82,0x82,0x82,0x7c,0x00,0x00}, //0
{0x00,0x00,0x84,0xfe,0x80,0x00,0x00,0x00}, //1
{0x00,0xe4,0x92,0x92,0x92,0x8c,0x00,0x00}, //2
{0x00,0x44,0x92,0x92,0x92,0x6c,0x00,0x00}, //3
{0x00,0x10,0x18,0x14,0xfe,0x10,0x10,0x00}, //4
{0x00,0x4e,0x8a,0x8a,0x8a,0x72,0x00,0x00}, //5
{0x00,0x7c,0x92,0x92,0x92,0x64,0x00,0x00}, //6
{0x00,0x02,0x02,0xfa,0x06,0x02,0x00,0x00}, //7
{0x00,0x6c,0x92,0x92,0x92,0x6c,0x00,0x00}, //8
{0x00,0x4c,0x92,0x92,0x92,0x7c,0x00,0x00} //9
};
uint timecount;
uchar a,b;
void Delay(uchar time)//延时函数
{
uchar i,j;
for(i=time;i0;i--)
for(j=320;j0;j--);
}
void Set595(unsigned char Data)
{
unsigned char i;
for(i = 0; i 8; i++)
{
SCK = 0; //先置为低
SER = Data 0x80; //取数据的最高位
Data = 1; //将数据的次高位移
原创力文档


文档评论(0)