心形花样LED流水灯(带程序)_第1页
心形花样LED流水灯(带程序)_第2页
心形花样LED流水灯(带程序)_第3页
心形花样LED流水灯(带程序)_第4页
心形花样LED流水灯(带程序)_第5页
已阅读5页,还剩11页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、心形花样LED流水灯(带程序) 使用89C52做的,原理图如下:总共有32个LED灯,4个I/O全部用上了。我在这里不加有LED保护电阻,用200的也可以晶振用12M的或11.0592M也行,C1,C2用30PF。PCB图如下:作品效果录像:程序是用C语言写的;如下:#include<reg52.h>#include <intrins.h>#defineuint unsigned int#defineuchar unsigned charuchar code table=0xfe,0xfc,0xf8,0xf0,0xe0,0xc0,0x80,0x00; / 逐个点亮07u

2、char code table1=0x7f,0x3f,0x1f,0x0f,0x07,0x03,0x01,0x00; / 逐个点亮70uchar code table2=0x01,0x03,0x07,0x0f,0x1f,0x3f,0x7f,0xff; / 逐个灭07uchar code table3=0x80,0xc0,0xe0,0xf0,0xf8,0xfc,0xfe,0xff; / 逐个灭70/*/void delay(uint t);/延时void zg(uint t,uchar a);/两边逐个亮void qs(uint t,uchar a);/全部闪烁void zgxh(uint t,u

3、char a); / 逆时针逐个点亮/void zgxh1(uint t,uchar a); / 顺时针逐个点亮void djs(uint t,uchar a); /对角闪void lbzgm(uint t,uchar a);/两边逐个灭/void sszgm(uint t,uchar a); / 顺时针逐个灭void nszgm(uint t,uchar a); / 逆时针逐个灭void sztl(uint t,uchar a);/顺时逐个同步亮void nztl(uint t,uchar a);/逆时逐个同步亮void sztm(uint t,uchar a);/顺时逐个同步灭void n

4、ztm(uint t,uchar a);/逆时逐个同步灭void hwzjl(uint t,uchar a); /横往中间亮void hwzjm(uint t,uchar a); /横往中间灭/void swzjl(uint t,uchar a); /竖往中间亮/void swzjm(uint t,uchar a); /竖往中间灭void nzdl(uint t,uchar a); /逆时逐段亮void nzdgl(uint t,uchar a); /逆时逐段一个点亮void jgs(uint t,uchar a); /间隔闪/*/void zg(uint t,uchar a)/两边逐个亮uc

5、har i,j; for(j=0;j<a;j+) P0=P1=P2=P3=0xff; P0=0x7f;delay(t); for(i=0;i<7;i+) P0=table1i+1; P2=table1i; delay(t); P2=0x00;P1=0xfe; delay(t); for(i=0;i<7;i+) P1=tablei+1;P3=table1i;delay(t); P3=0x00;delay(t); void qs(uint t,uchar a) /全部闪烁uchar j;for(j=0;j<a;j+) P0=P1=P2=P3=0xff; delay(t);

6、P0=P1=P2=P3=0x00; delay(t); void zgxh(uint t,uchar a) / 逆时针逐个点亮uchar i,j;for (j=0;j<a;j+)P0=P1=P2=P3=0xff;for (i=0;i<8;i+)P0=table1i;delay(t);for(i=0;i<8;i+)P1=tablei;delay(t);for(i=0;i<8;i+)P3=tablei;delay(t);for(i=0;i<8;i+)P2=tablei;delay(t);void nszgm(uint t,uchar a) / 逆时针逐个灭uchar

7、i,j;for(j=0;j<a;j+)P0=P1=P2=P3=0x00;for (i=0;i<8;i+)P0=table3i;delay(t);for (i=0;i<8;i+)P1=table2i;delay(t);for (i=0;i<8;i+)P3=table2i;delay(t);for (i=0;i<8;i+)P2=table2i;delay(t);/*void zgxh1(uint t,uchar a) / 顺时针逐个点亮uchar i,j;for (j=0;j<a;j+)P0=P1=P2=P3=0xff;for (i=0;i<8;i+)P2

8、=table1i;delay(t);for(i=0;i<8;i+)P3=table1i;delay(t);for(i=0;i<8;i+)P1=table1i;delay(t);for(i=0;i<8;i+)P0=tablei;delay(t); */ /*void sszgm(uint t,uchar a) / 顺时针逐个灭uchar i,j;for(j=0;j<a;j+)P0=P1=P2=P3=0x00;for (i=0;i<8;i+)P2=table3i;delay(t);for (i=0;i<8;i+)P3=table3i;delay(t);for (

9、i=0;i<8;i+)P1=table3i;delay(t);for (i=0;i<8;i+)P0=table2i;delay(t);*/void djs(uint t,uchar a) /对角闪uchar j;for(j=0;j<a;j+)P0=P1=P2=P3=0xff;P0=P3=0x00;delay(t);P0=P1=P2=P3=0xff;P1=P2=0x00;delay(t);void lbzgm(uint t,uchar a)/两边逐个灭 uchar i,j; for (j=0;j<a;j+) P0=P2=0x00;P3=0x01;delay(t);for(

10、i=7;i>1;i-)P1=tablei-1;P3=table1i-2;delay(t);P1=0xfe;P3=0xff;delay(t);P1=0xff;P2=0x01;delay(t);for(i=7;i>1;i-)P0=table1i-1;P2=table1i-2;delay(t);P0=0x7f;P2=0xff;delay(t);P0=0xff;delay(t); void sztl(uint t,uchar a)/顺时逐个同步亮uchar i,j;for(j=0;j<a;j+)P0=P1=P2=P3=0xff;for(i=0;i<8;i+)P0=tablei;

11、P1=P2=P3=table1i;delay(t);void nztl(uint t,uchar a)/逆时逐个同步亮uchar i,j;for(j=0;j<a;j+)P0=P1=P2=P3=0xff;for(i=0;i<8;i+)P0=table1i;P1=P2=P3=tablei;delay(t);void sztm(uint t,uchar a)/顺时逐个同步灭uchar i,j;for(j=0;j<a;j+)P0=P1=P2=P3=0x00;for(i=0;i<8;i+)P0=table2i;P1=P2=P3=table3i;delay(t);void nztm

12、(uint t,uchar a)/逆时逐个同步灭uchar i,j;for(j=0;j<a;j+)P0=P1=P2=P3=0xff;for(i=0;i<8;i+)P0=table3i;P1=P2=P3=table2i;delay(t);void hwzjl(uint t,uchar a) /横往中间亮uchar i,j;for (j=0;j<a;j+)P0=P1=P2=P3=0xff;for(i=0;i<8;i+)P0=P2=P1=table1i;P3=tablei;delay(t);void hwzjm(uint t,uchar a) /横往中间灭uchar i,j;

13、for (j=0;j<a;j+)P0=P1=P2=P3=0x00;for(i=0;i<8;i+)P0=P2=P1=table3i;P3=table2i;delay(t);/*void swzjl(uint t,uchar a) /竖往中间亮uchar i,j;for (j=0;j<a;j+)P0=P1=P2=P3=0xff;for(i=0;i<8;i+)P0=P2=P1=tablei;P3=table1i;delay(t);void swzjm(uint t,uchar a) /竖往中间灭uchar i,j;for (j=0;j<a;j+)P0=P1=P2=P3=

14、0x00;for(i=0;i<8;i+)P0=P2=P1=table2i;P3=table3i;delay(t);*/void nzdl(uint t,uchar a) /逆时逐段亮uchar i,j;for (j=0;j<a;j+)P0=P1=P2=P3=0xff;for(i=0;i<8;i+)P0=table1i;delay(t);P0=0xff;for(i=0;i<8;i+)P1=tablei;delay(t);P1=0xff;for(i=0;i<8;i+)P3=tablei;delay(t);P3=0xff;for(i=0;i<8;i+)P2=tab

15、lei;delay(t);P2=0xff;void nzdgl(uint t,uchar a) /逆时逐段一个点亮uchar i,j,k,l;for (j=0;j<a;j+)k=table10;P0=k;l=table0;P1=P2=P3=l;delay(t);for(i=0;i<8;i+)k=_crol_(k,-1);P0=k;l=_crol_(l,1);P1=P2=P3=l;delay(t);void jgs(uint t,uchar a) /间隔闪uchar j;for (j=0;j<a;j+)P0=0x55;P1=P2=P3=0xaa;delay(t);P0=0xaa

16、;P1=P2=P3=0x55;delay(t);void main()uchar i;while(1) zg(100,1); /两边逐个亮 lbzgm(100,1); /两边逐个灭 jgs(300,10); djs(100,20); /对角闪/P1=P2=P3=0xff;for(i=0;i<3;i+) P0=0x00;delay(800); P0=0xff;delay(800); P0=0x00; for(i=0;i<3;i+) P1=0x00;delay(800); P1=0xff;delay(800); P1=0x00; for(i=0;i<3;i+) P3=0x00;d

17、elay(800); P3=0xff;delay(800); P3=0x00; for(i=0;i<3;i+) P2=0x00;delay(800); P2=0xff;delay(800); qs(500,3);/for(i=0;i<6;i+) zgxh(50,1); nszgm(50,1); djs(100,20); /对角闪for(i=0;i<3;i+) zg(100,1); /两边逐个亮 lbzgm(100,1); /两边逐个灭 qs(200,10);djs(100,50); for(i=0;i<5;i+) sztl(200,1); /顺时逐个同步亮nztm(20

18、0,1); nztl(200,1);sztm(200,1); /顺时逐个同步灭 djs(300,10); /对角闪 nzdgl(300,10); /逆时逐段一个点亮 jgs(300,10); /间隔闪for(i=0;i<3;i+) zgxh(100,1); nszgm(100,1); /*for(i=0;i<5;i+) zgxh1(100,1); sszgm(100,1); */ nzdl(200,3); /逆时逐段亮 jgs(50,100); /间隔闪/*/P0=P1=P2=P3=0xff;for (i=0;i<8;i+)P0=table1i;delay(200);for

19、(i=0;i<8;i+)P1=tablei;delay(200);for(i=0;i<3;i+)P0=P1=0x00;delay(200);P0=P1=0xff;delay(200);for (i=0;i<8;i+)P2=table1i;delay(200);for (i=0;i<8;i+)P3=table1i;delay(200);for(i=0;i<3;i+)P2=P3=0x00;delay(200);P2=P3=0xff;delay(200);*/nzdgl(50,40); /逆时逐段一个点亮for(i=0;i<4;i+) zg(100,1);qs(100,10); lbzgm(10

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论