|
#include<reg52.h>
#define uint unsigned int
#define uchar unsigned char
uchar time,distance,ge,shi,bai;
sbit Trig=P0^0; //超聲波發射
sbit Echo=P0^1; //回波接收
sbit smg0=P2^0; //數碼管0位選
sbit smg1=P2^1; //數碼管1位選
sbit smg2=P2^2; //數碼管2位選
sbit smg3=P2^3; //數碼管3位選
uchar code table[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90}; //四位共陽數碼管段碼
void delay(uchar i)
{
uchar j,k;
for(j=i;j>0;j--)
for(k=125;k>0;k--);
}
/*
**********************************************
* 函 數 名 :超聲波測距
* 功能說明 :啟動超聲波,并計算距離
* 形 參 :無
* 返 回 值 :int distance
**********************************************
*/
int chaoshengbo(void)
{
TH0=0;
TL0=0;
Trig=0;
delay(1);
Trig=1;
delay(10);
while(!Echo);
{
TR0=1;
}
while(Echo);
{
TR0=0;
time=TH0*256+TL0;
distance=(time*1.7)/100;
return distance;
}
}
/*
**********************************************
* 函 數 名 :測量距離數碼管顯示
* 功能說明 :用四位共陽數碼管顯示測量距離
* 形 參 :uint distance
* 返 回 值 :無
**********************************************
*/
void display(int distance)
{
bai=distance/100;
shi=distance%100/10;
ge=distance/10;
P0=table[bai];
smg0=0;
delay(5);
smg0=1;
P0=table[bai];
smg0=0;
delay(5);
smg0=1;
P0=table[shi];
smg1=0;
delay(5);
smg1=1;
P0=table[ge];
smg2=0;
delay(5);
smg2=1;
}
/*
**********************************************
* 函 數 名 :主函數
* 功能說明 :
* 形 參 :無
* 返 回 值 :無
**********************************************
*/
void main(void)
{ //4位共陽數碼管顯示超聲波測的距離
distance=chaoshengbo();
display(distance); //超聲波測距,返回一個整形參數distanc
}
|
|