博客
关于我
51单片机——LED流水灯
阅读量:681 次
发布时间:2019-03-17

本文共 1212 字,大约阅读时间需要 4 分钟。

51单片机——LED流水灯

一、查表法实现流水灯

查看开发板的原理图,知道了控制LED2~LED7的端口为P0口,所以可以通过对P0口赋值控制发光二极管的亮灭。比如,用十六进制表示P0的值,P0=0xfe,即LED2发光,其他LED熄灭。要实现流水灯的话,让发光二极管从LED2到LED7顺序发光就可以了,也就是说,P0口的值依次为0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f,简简单单。

 

而查表法就是把P0口要表示的值做成数组,再利用'code'将其存入ROM中,使用时,让P0口等于数组中的某个值。

程序如下:

#include 
sbit ADDR0=P1^0; sbit ADDR1=P1^1;sbit ADDR2=P1^2;sbit ADDR3=P1^3;sbit ENLED=P1^4;void delay(unsigned char x);unsigned char code aa[]=//P0口查表{0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};void main(){ unsigned i; ADDR0=0; //按原理图端口初始化 ADDR1=1; ADDR2=1; ADDR3=1; ENLED=0; while(1) { for(i=0;i<8;i++) { P0=aa[i]; delay(250); } }}void delay(unsigned char x){ unsigned n; while(--x) for(n=0;n<250;n++);}

二、循环法

用查表法实现流水灯时,发现对P0口赋值是由规律的,即0的位置在左移,如果让0左移到最高位后,重新从最低为开始左移,也可以实现流水灯。介就是循环法,也是蛮简单的,可以加入一个叫'intrins.h'的头文件来做。

程序如下:

#include 
#include
sbit ADDR0=P1^0; sbit ADDR1=P1^1;sbit ADDR2=P1^2;sbit ADDR3=P1^3;sbit ENLED=P1^4;void delay(unsigned char x);void main(){ unsigned char i,a=0xfe; ADDR0=0; //按原理图端口初始化 ADDR1=1; ADDR2=1; ADDR3=1; ENLED=0; while(1) { for(i=0;i<8;i++) { P0=a; a=_crol_(a,1); delay(250); } }}void delay(unsigned char x){ unsigned n; while(--x) for(n=0;n<250;n++);}

 

转载地址:http://jmgqz.baihongyu.com/

你可能感兴趣的文章
Mysql学习总结(11)——MySql存储过程与函数
查看>>
Mysql学习总结(12)——21分钟Mysql入门教程
查看>>
Mysql学习总结(13)——使用JDBC处理MySQL大数据
查看>>
Mysql学习总结(14)——Mysql主从复制配置
查看>>
Mysql学习总结(15)——Mysql错误码大全
查看>>
Mysql学习总结(16)——Mysql之数据库设计规范
查看>>
Mysql学习总结(17)——MySQL数据库表设计优化
查看>>
Mysql学习总结(18)——Mysql主从架构的复制原理及配置详解
查看>>
Mysql学习总结(19)——Mysql无法创建外键的原因
查看>>
Mysql学习总结(19)——Mysql无法创建外键的原因
查看>>
Mysql学习总结(1)——常用sql语句汇总
查看>>
Mysql学习总结(20)——MySQL数据库优化的最佳实践
查看>>
Mysql学习总结(21)——MySQL数据库常见面试题
查看>>
Mysql学习总结(22)——Mysql数据库中制作千万级测试表
查看>>
Mysql学习总结(23)——MySQL统计函数和分组查询
查看>>
Mysql学习总结(24)——MySQL多表查询合并结果和内连接查询
查看>>
Mysql学习总结(25)——MySQL外连接查询
查看>>
Mysql学习总结(26)——MySQL子查询
查看>>
Mysql学习总结(27)——Mysql数据库字符串函数
查看>>
Mysql学习总结(28)——MySQL建表规范与常见问题
查看>>