#include <reg51.h>
#include <intrins.h>
#include <STDIO.H>
sbit RX=P2^1;
sbit TX=P2^0;
sbit buzzer=P2^5;
unsigned int time=0;
unsigned int timer=0;
unsigned long S=0;
bit flag =0;
/***************************************************
函數功能:延時1ms
(3j+2)*i=(3×33+2)×10=1010(微秒),可以認為是1毫秒
***************************************************/
void delay1ms()
{
unsigned char i,j;
for(i=0;i<10;i++)
for(j=0;j<33;j++);
}
/*****************************************************
函數功能:延時若干毫秒
入口參數:n
***************************************************/
void delay(unsigned char n)
{
unsigned char i;
for(i=0;i<n;i++)
delay1ms();
}
/********************************************************/
void Conut(void)
{
time=TH0*256+TL0;
TH0=0;
TL0=0;
S=(long)(time*0.17); //算出來是CM
if(flag==1) //超出測量范圍蜂鳴器一直響
{
flag=0;
buzzer=1;
}
else
{
buzzer=1;
delay(100*S);
buzzer=0;
delay(100*S);
}
}
/*******************************************************/
void zd0() interrupt 1 //T0中斷用來計數器溢出,超過測距范圍
{
flag=1; //中斷溢出標志
}
/******************************************************/
void zd3() interrupt 3//StartModule() //T1中斷用來計800MS啟動模塊
{
TH1=0xf8;
TL1=0x30;
timer++;
if(timer>=100)
{
timer=0;
TX=1; //800MS 啟動一次模塊
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
TX=0;
}
}
/*********************************************************/
void main( void )
{
TMOD=0X21;//0x11; //設T0為方式1,GATE=1;
SCON=0x50;
TH0=0;
TL0=0;
TH1=0xf8;
TL1=0x30;
ET0=1; //允許T0中斷
TR0=1;
ET1=1;
TR1=1;
//開啟定時器
//TI=1;
EA=1; //開啟總中斷
while(1)
{
//StartModule();
while(!RX); //當RX為零時等待
TR0=1; //開啟計數
while(RX); //當RX為1計數并等待
TR0=0; //關閉計數
Conut(); //計算
//delay(100); //100MS
}
}
|