51c单片机开发

//TX-1C实验板
//芯片 STC89C52RC
//晶振频率 11.0592MHz
//=====一个LED灯闪
#include<reg52.h>
#define uint unsigned int
sbit led1=P1^0;
void delay1s();
void main()
{
	while(1)
	{
		led1=0;
		delay1s();
		led1=1;
		delay1s();
	}
}
void delay1s()
{
	uint i,j;
	for(i=500;i>0;i--)
		for(j=110;j>0;j--);
}
//======流水灯程序
#include<reg52.h>
#include<intrins.h>
#define uint unsigned int
#define uchar unsigned char
void delayms(uint xms);
uchar aa;
void main()
{
	aa=0xfe;
	while(1)
	{
		P1=aa;;
		delayms(500);
		aa=_crol_(aa,1);
	}
}
void delayms(uint xms)
{
	uint i,j;
	for(i=xms;i>0;i--)
		for(j=110;j>0;j--);
}
//=====启动蜂鸣
#include<reg52.h>
#include<intrins.h>
#define uint unsigned int
#define uchar unsigned char
sbit beep=P2^3;
void delay(uint z);
void main()
{	
	while(1)
	{
		beep=0;
		delay(100);	
		beep=1;
		delay(10000000);
	}
}
void delay(uint z)
{
	uint x,y;
	for(x=z;x>0;x--)
		for(y=110;y>0;y--);
}
//======数码管的显示;数字6
#include<reg52.h>
sbit dula=P2^6;
sbit wela=P2^7;
void main()
{
	wela=1;
	P0=0xfe;
	wela=0;
	dula=1;
	P0=0x7d;
	dula=0;
	while(1);
}
//======数码管的静态显示
#include<reg52.h>
#define uint unsigned int 
#define uchar unsigned char
sbit dula=P2^6;
sbit wela=P2^7;
uchar num;
uchar code table[]={
	0x3f,0x06,0x5b,0x4f,
	0x66,0x6d,0x7d,0x07,
	0x7f,0x6f,0x77,0x7c,
	0x39,0x5e,0x79,0x71
};
void delayms(uint);
void main()
{
	wela=1;
	P0=0xc0;
  wela=0;
	while(1)
	{
		for(num=0;num<16;num++)
			{
				dula=1;
				P0=table[num];
				dula=0;
				delayms(1000);
			}
	}
}
void delayms(uint xms)
{
	 uint x,y;
	 for(x=xms;x>0;x--)
	  for(y=110;y>0;y--);
}
//======数码管的动态显示
#include<reg52.h>
#define uint unsigned int 
#define uchar unsigned char
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
};
void delayms(uint);
void main()
{
	while(1)
	{
		dula=1;
		P0=table[1];
		dula=0;
		P0=0xff;
		wela=1;
		P0=0xfe;
		wela=0;
		delayms(500);
		
		dula=1;
		P0=table[2];
		dula=0;
		P0=0xff;
		wela=1;
		P0=0xfd;
		wela=0;
		delayms(500);
		
		dula=1;
		P0=table[3];
		dula=0;
		P0=0xff;
		wela=1;
		P0=0xfb;
		wela=0;
		delayms(500);
		
		dula=1;
		P0=table[4];
		dula=0;
		P0=0xff;
		wela=1;
		P0=0xf7;
		wela=0;
		delayms(500);
		
		dula=1;
		P0=table[5];
		dula=0;
		P0=0xff;
		wela=1;
		P0=0xef;
		wela=0;
		delayms(500);
		
		dula=1;
		P0=table[6];
		dula=0;
		P0=0xff;
		wela=1;
		P0=0xdf;
		wela=0;
		delayms(500);
		
	}
}
void delayms(uint xms)
{
	 uint x,y;
	 for(x=xms;x>0;x--)
	  for(y=110;y>0;y--);
}
//======
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值