当前位置: 首页 > article >正文

51单片机程序

利用动态扫描和定时器1在数码管上显示出从765432开始以1/10秒的速度往下递减直至765398并保持显示此数,与此同时利用定时器O以500MS速度进行流水灯从土至下移动,当数码管上数减到停止时,实验板上流水灯也停止然后全部开始闪烁,3秒后(用TO定时)流水灯全部关闭、数码管上显示出"HELLO”。到此保持住。

#include <reg52.h>
#include <intrins.h>
#define uchar unsigned char
#define uint unsigned int
uchar temp,t0,t1,bai,shi,ge,flag,flag1;
uint shu;

sbit dula=P2^6;
sbit wela=P2^7;
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71,
0x36,0x79,0x38,0x3f,0};

void init();
void delay(uint z);
void display(uchar aa,uchar bb,uchar cc,uchar bai,uchar shi,uchar ge);
void main()
{
	
    init();
	while(1)
	{	if(flag1!=1)
			display(7,6,5,bai,shi,ge);
		else
			display(16,17,18,18,19,20);
	}
}

void init()
{
	shu=432;
	temp=0xfe;
	P1=temp;//点亮第一个发光二极管
	TMOD=0x11;
	TH0=(65536-5000)/256;//装初值
	TL0=(65536-5000)%256;
	TH1=(65536-5000)/256;//定时器1装初值
	TL1=(65536-5000)%256;
	EA=1;
	ET0=1;
	ET1=1;//开定时器1
	TR0=1;
    TR1=1;//启动定时器1
}

void timer0() interrupt 1
{
	TH0=(65536-5000)/256;//装初值
	TL0=(65536-5000)%256;
	t0++;
	if(flag!=1)
	{
		if(t0==10)
			{
				t0=1;
		        temp=_crol_(temp,1);
				P1=temp;
			}
	}else
	{
		if(t0%4==0)	
			P1=~P1;	

		if(t0==60)
		{	
			TR0=0;
			P1=0xff;
			flag1=1;
		}
	}
}

void timer1() interrupt 3
{
	TH1=(65536-5000)/256;//装初值
	TL1=(65536-5000)%256;
	t1++;
	if(t1==2)
	{
		t1=0;
		shu--;
		bai=shu/100;
		shi=shu%100/10;
		ge=shu/10;
		if(shu==398)
		{	
			TR0=0;
			TH0=(65536-5000)/256;//装初值
			TL0=(65536-5000)%256;
			TR0=1;
			flag=1;
			t0=0;
			P1=0xff;
			TR1=0;
			
		}
	}
}

void display(uchar aa,uchar bb,uchar cc,uchar bai,uchar shi,uchar ge)
{
	dula = 1;
	P0=table[aa];
	dula =0;
	P0=0xff;
	wela=1;
	P0=0xfe;
	wela=0;
	delay(1);
	
	dula = 1;
	P0=table[bb];
	dula =0;
	P0=0xff;
	wela=1;
	P0=0xfd;
	wela=0;
	delay(1);

	dula = 1;
	P0=table[cc];
	dula=0;
	P0=0xff;
	wela=1;
	P0=0xfb;
	wela=0;
	delay(1);

    dula = 1;
	P0=table[bai];
	dula=0;
	P0=0xff;
	wela=1;
	P0=0xf7;
	wela=0;
	delay(1);

    dula = 1;
	P0=table[shi];
	dula=0;
	P0=0xff;
	wela=1;
	P0=0xef;
	wela=0;
	delay(1);

	dula = 1;
	P0=table[ge];
	dula=0;
	P0=0xff;
	wela=1;
	P0=0xdf;
	wela=0;
	delay(1);
}
void delay(uint z)
{	
	uint x,y;
	for(x=z;x>0;x--)
		for(y=110;y>0;y--);
}


http://www.kler.cn/a/161021.html

相关文章:

  • Ubuntu网络连接问题(笔记本更换wifi后,虚拟机连不上网络)
  • 测试ip端口-telnet开启与使用
  • 计算机网络——网络层—IP数据报与分片
  • 云安全博客阅读(三)
  • thinkphp6.0常用设计模式实例
  • c#使用SevenZipSharp实现压缩文件和目录
  • 使用广播机制将for循环转为矩阵运算
  • matlab 点云放缩变换
  • [linux] 解压缩xz
  • 高精度加法,减法,乘法,除法(上)(C语言)
  • Doris 编译错误 error: No best alternative for libs/context/build/asm_sources
  • Python计算两个给定单词之间相同字符的数量
  • methods
  • kafka3.6.0部署
  • 分享一个基础面试题---手写call
  • UDP Socket API 的讲解,以及回显服务器客户端的实现
  • 如何在Linux上部署1Panel运维管理面板并远程访问内网Web端管理界面
  • 图像瞎总结
  • 深入了解MySQL临时表的使用和优势
  • 简谈PostgreSQL的wal_level=logic
  • RT_Thread_使用FAL组件配置stm32f407片上flash读写
  • 亚马逊云科技re:Invent,生成式AI正在彻底改变开发者的工作方式
  • 无与伦比的夜景增强技术解决方案
  • 【智能家居】二、添加火灾检测模块(烟雾报警功能点)
  • 普华永道:国有企业要动态布局和管理供应商资源池
  • 【c】杨辉三角