本文包含原理图、PCB、源代码、封装库、中英文PDF等资源
您需要 登录 才可以下载或查看,没有账号?注册会员
×
以16进制发送一个0-65536之间的任一数,当单片机收到后在数码管上动态显示出来,波特率自定。
#include <reg52.h>
#define uchar unsigned char
#define uint unsigned int
uchar flag,wan,qian,bai,shi,ge;
uchar k,x;
uint c;
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71};
uint temp[2]={0,0};
sbit dula=P2^6;
sbit wela=P2^7;
void delay(uint z)
{
uint x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
void init()
{
TMOD=0x20;
TH1=0xfd;
TL1=0xfd;
TR1=1;
SM0=0;
SM1=1;
REN=1;
EA=1;
ES=1;
dula=1;
P0=0;
dula=0;
k=0;
x=0;
}
void display(uchar aa,uchar bb,uchar cc,uchar dd,uchar ee) //数字扫描
{
dula=1;
P0=table[aa];
dula=0;
P0=0xff;
wela=1;
P0=0xfe;
wela=0;
delay(2);
dula=1;
P0=table[bb];
dula=0;
P0=0xff;
wela=1;
P0=0xfd;
wela=0;
delay(2);
dula=1;
P0=table[cc];
dula=0;
P0=0xff;
wela=1;
P0=0xfb;
wela=0;
delay(2);
dula=1;
P0=table[dd];
dula=0;
P0=0xff;
wela=1;
P0=0xf7;
wela=0;
delay(2);
dula=1;
P0=table[ee];
dula=0;
P0=0xff;
wela=1;
P0=0xef;
wela=0;
delay(2);
}
void main()
{
init();
while(1)
{
if(flag==1)
{
wan=c/10000;
qian=c%10000/1000;
bai=c%1000/100;
shi=c%100/10;
ge=c%10;
flag=0;
ES=0;
SBUF=wan;
while(!TI);
TI=0;
SBUF=qian;
while(!TI);
TI=0;
SBUF=bai;
while(!TI);
TI=0;
SBUF=shi;
while(!TI);
TI=0;
SBUF=ge;
while(!TI);
TI=0;
ES=1;
x=0;
k=0;
}
display(wan,qian,bai,shi,ge);
}
}
void ser() interrupt 4 //就是这段串口中断没搞懂。。。
{
while(RI==1) //弱弱地问一句、、这个 while(R1==1) 是神马意思呢。。。
{
if(k==2)
k=0;
temp[k]=SBUF;
RI=0;
k++;
x++;
if(x==3)
x=1;
}
if(x==2)
c=(temp[0]*256)+temp[1]; //还有输入的数是怎么赋给c的呢。。。
if(x==1)
c=temp[0];
flag=1;
} |