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--);
}

相关推荐

  1. 51单片机程序

    2023-12-07 11:54:01       53 阅读
  2. 51单片机c语言烧录软件,51单片机烧写程序的方法

    2023-12-07 11:54:01       59 阅读
  3. 51单片机超声波测距

    2023-12-07 11:54:01       61 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-07 11:54:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-07 11:54:01       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-07 11:54:01       87 阅读
  4. Python语言-面向对象

    2023-12-07 11:54:01       96 阅读

热门阅读

  1. uniapp-获取手机型号

    2023-12-07 11:54:01       60 阅读
  2. 网页产品经理常用的ChatGPT通用提示词模板

    2023-12-07 11:54:01       68 阅读
  3. 27、数据存储&秒表(定时器扫描按键数码管)

    2023-12-07 11:54:01       55 阅读
  4. 【C++】时间time库

    2023-12-07 11:54:01       64 阅读
  5. 【力扣100】2.字母异位词分组

    2023-12-07 11:54:01       65 阅读
  6. openCv颜色矩

    2023-12-07 11:54:01       52 阅读
  7. js实现多个word合并,使用docx-merger库

    2023-12-07 11:54:01       54 阅读
  8. Xubuntu16.04系统中使用RTL8822CE8821无线网卡

    2023-12-07 11:54:01       195 阅读