找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2992|回復: 1
打印 上一主題 下一主題
收起左側

[求助]

[復制鏈接]
跳轉到指定樓層
樓主
ID:49378 發(fā)表于 2013-4-23 20:19 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式

程序如下,調試時出現(xiàn)錯誤。求高手指導。。幫忙找出錯誤~~~

#include<reg52.h>
#define uchar unsigned char
#define uint unsigned int
sbit trig=P1^0;
sbit echo=P3^2;
sbit test=P1^2;
uchar distance,time,outH,outL;
void delay_20us();
void delay(uint);
void nint();
void count();

void main()
{
while(1)
{
nint();
delay(100);
trig=1;
delay_20us();
trig=0;
while(!echo)
TR0=0;
while(echo)
TR0=1;
delay(1000);
count();
}
}

void init() //初始化函數(shù)
{
trig=0;
echo=0;
test=1;
//外部中斷
EA=1;
EX0=1;
IT0=0;
//T0中斷
TMOD=0X01;
TH0=0;
TL0=0;
ET0=1;
TR0=0;
}

void INT0_time() interrupt 0 //外部0中斷函數(shù)
{
TR0=1;
while(!echo)
TR0=0;
outH=TH0;
outL=TL0;
}

void T0_time() interrupt 1 //定時器中斷函數(shù)
{
TH0=0;
TL0=0;
}

void count()
{
time=outH*256+outL;
distance=(time*17)/1000;
if(distance<20&&distance!=0)
test=0;
}

void delay_20us()
{
uint i;
for(i=0;i<100;i++);
}

void delay(uint z)
{
uint x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發(fā)
ID:49378 發(fā)表于 2013-4-23 20:20 | 只看該作者
關于超聲波測距的程序~求助~~
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表