【51单片机篇】超声波测距

 

#include "reg52.h"

sbit D5 = P3^7;
sbit D6 = P3^6;
sbit Trig = P1^5;
sbit Echo = P1^6;

void Delay10us()		//@11.0592MHz
{
	unsigned char i;

	i = 2;
	while (--i);
}

void Time0Init()
{
	TMOD &= 0xF0;
	TMOD |= 0x01;
	TH0 = 0;
	TL0 = 0;
	//设置定时器0工作模式1,初始值设定0开始数数,不着急启动定时器
}

void startHC()
{
	Trig = 0;
	Trig = 1;
	Delay10us();
	Trig = 0;
}
//距离小于10cm,D5亮,D6灭,反之现象相反
void main()
{
	double time;
	double dis;
	
	Time0Init();
	while(1){
		//1. 给Trig一个至少10us高电平
		startHC();
		//2. 由低电平跳转到高电平,表示开始发送波
		while(Echo == 0);
		//波出去的那一下,开启定时器
		TR0 = 1;
		//3. 由高电平跳转到低电平,表示波回来了
		while(Echo == 1);
		//波回来的那一下,停止定时器
		TR0 = 0;
		//4. 计算出中间经过多少时间
		time = (TH0 * 256 + TL0)*1.085;//二进制1左移1位,变成10(2),相当于乘以2,左移8位,相当于乘以2的8次方=256
		//5. 距离=速度(340m/s)*时间/2
		dis = time * 0.017;
		if(dis < 10){
			D5 = 0;
			D6 = 1;
		}else{
			D5 = 1;
			D6 = 0;
		}
		//定时器数据清零,以便下一次测距
		TH0 = 0;
		TL0 = 0;
	}
}

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序猿gao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值