51单片机4种流水灯

51单片机4种流水灯4种流水灯:1、先从右到左逐个亮灭;再从左到右逐个亮灭;2、由两侧向中间,再中间向两侧亮灭;3、先右再左逐个亮起,不熄灭;再从左到右逐个熄灭;4、先左再右逐个亮起,不熄灭;再从右到左逐个熄灭;

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

  • 程序说明: LED连接在P2引脚上。
  • 程序现象:
    1、先从右到左逐个亮灭;再从左到右逐个亮灭;
    2、由两侧向中间,再中间向两侧亮灭;
    3、先右再左逐个亮起,不熄灭;再从左到右逐个熄灭;
    4、先左再右逐个亮起,不熄灭;再从右到左逐个熄灭;
#include "reg52.h" 

#define led P2	//对整个P2端口进行操作

/*	延时函数		*/
void delay(unsigned int del) 	//10ms * del
{
	unsigned int i,j;
	for(i=0; i<del; i++)
	for(j=0; j<1827; j++)      
	    ;
}

void  Led_Pipeline_1() //先从右到左逐个亮灭;再从左到右逐个亮灭;
{
	unsigned  char i;	
	delay(10); 
	led=0xfe;	//初始状态将LED0点亮

	for(i=0;i<8;i++)//	1111 1110
	{
		P2=~(0x01<<i);	 //将0000 0001左移i位,然后将结果取反赋值到P2口
		delay(20); 	//大约延时200ms
	}
//	led=0xFF; //熄灭所有LED
//	delay(20); 
	for(i=1;i<8;i++)
	{
		P2=~(0x80>>i);	 //将1右移i位,然后将结果取反赋值到P2口
		delay(20); 
	}	
//	led=0xFF; //熄灭所有LED
}
void Led_Pipeline_2() //两侧向中间,再中间向两侧亮灭
{
	unsigned  char i,High,Low;
	delay(20);
	led=0x7E;	//初始状态将两侧点亮
	High=led&0xF0;	//高四位 0111 0000
	Low=led&0x0F;	//低四位 0000 1110 
	delay(30);
	for(i=0;i<3;i++)
	{
		High=~(~High>>1);	 //将0x8F右移1位 0100 0111, 1011 1000
		Low=~(~Low<<1);	     //将0xFE左移1位
		
		led=(High&0xF0)|(Low&0x0F);//保证高位、低位不受到移位影响
		delay(30);
	}	
//	led=0xFF; //熄灭所有LED
//	delay(20);
//	led=0xE7;//初始状态将中间两颗LED点亮
//	delay(30);
	for(i=0;i<3;i++)
	{						 //1110 0111
		High=~(~High<<1);	 //将0x1*左移i位
		Low=~(~Low>>1);	 	 //将0x*8右移i位  
		
		led=(High&0xF0)|(Low&0x0F);//保证高位、低位不受到移位影响
		delay(30);
	}	
	led=0xFF; //熄灭所有LED
}

void Led_Pipeline_3() //先右再左逐个亮起,不熄灭;再从左到右逐个熄灭;
{
	unsigned  char i;	
	delay(20);
	led=0xfe;	//初始状态将LED0点亮
	delay(10);
	for(i=0;i<8;i++)
	{
		P2=0xFE<<i;	 //将1111 1110左移i位,然后将结果赋值到P2口
		delay(10); 	//大约延时100ms
	}
	led=0xFF; //熄灭所有LED
	for(i=0;i<8;i++)
	{
		P2=~(0xFF>>i);	 //将1111 1111右移i位,然后将结果取反赋值到P2口
		delay(10); 
	}	
	led=0xFF; //熄灭所有LED
}

void Led_Pipeline_4() //先左再右逐个亮起,不熄灭;再从右到左逐个熄灭;
{
	unsigned  char i;	
	delay(20);
	led=0x7F;	
	delay(10);
	for(i=0;i<8;i++)
	{
		P2=0x7F>>i;	 
		delay(10); 
	}
	led=0xFF; 
	for(i=0;i<8;i++)
	{
		P2=~(0xFF<<i);
		delay(10); 
	}	
	led=0xFF; //熄灭所有LED
}
void main()
{
	while(1)
	{
		Led_Pipeline_1();
		Led_Pipeline_2();
		Led_Pipeline_3();
		Led_Pipeline_4();
	}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/132933.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • JVM内存结构图解

    JVM内存结构图解一 真实系统中的概念  JVM(JavaVirtualMachine),顾名思义是对真实计算机系统的模拟,正因如此才能屏蔽物理机器的变化,从而实现“一次编译,到处运行”。  相信很多Java程序员经常听到堆、栈等概念,也会进行设置调优以让Java应用能够更好地运行,但对于JVM与真实计算机系统之间的关系并没有特别清晰的认识。因此,这里先简单介绍下真实计算机系统中的一

  • apimodelproperty注解不生效(注解是什么)

    https://blog.csdn.net/weixin_44356055/article/details/109451892

  • 2012年第一篇博文——致谢:2011年中国IT十大杰出博客获奖感言「建议收藏」

    2012年第一篇博文——致谢:2011年中国IT十大杰出博客获奖感言「建议收藏」在2012新年伊始之际,非常荣幸获得了2011年度十大杰出IT博客的殊荣,非常感谢各界朋友和同仁、51CTO的编辑、《网络协议本质论》和《蜕变:从菜鸟到Linux安全专家》等个人专著的热心读者在大赛期间对我的支持、关心和陪伴。51CTO博客是一个非常好的展示自己、促进交流、提升自我的平台。我以前专注于技术研究和项目管理,2年前通过51CTO这么一个好的平台找到了一条与大…

  • 整除计算器_整除

    整除计算器_整除原题链接这里所谓的“光棍”,并不是指单身汪啦~ 说的是全部由1组成的数字,比如1、11、111、1111等。传说任何一个光棍都能被一个不以5结尾的奇数整除。比如,111111就可以被13整除。 现在,你的程序要读入一个整数x,这个整数一定是奇数并且不以5结尾。然后,经过计算,输出两个数字:第一个数字s,表示x乘以s是一个光棍,第二个数字n是这个光棍的位数。这样的解当然不是唯一的,题目要求你输出最小的解。提示:一个显然的办法是逐渐增加光棍的位数,直到可以整除x为止。但难点在于,s可能是个非常大的数 ——

  • scrapy安装步骤_linux下安装scrapy

    scrapy安装步骤_linux下安装scrapy1、Scrapy是什么Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架。可以应用在包括数据挖掘,信息处理或存储历史数据等一系列的程序中。2、scrapy安装安装过程中出错:如果安装出现一下错误building‘twisted.test.raiser’extensionerror:MicrosoftVisualC++14.0isrequired.Getitwith“MicrosoftVisualC++BuildTools”:http://l

  • s3c2440时钟频率「建议收藏」

    s3c2440时钟频率「建议收藏」分类:LINUX++++++++++++++++++++++++++++++++++++++++++本文系本站原创,欢迎转载!转载请注明出处:http://blog.csdn.net/mr_raptor/article/details/6555734++++++++++++++++++++++++++++++++++++++++++系统时钟MINI2440开发板

发表回复

您的电子邮箱地址不会被公开。

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