蓝桥杯单片机——超声波

程序

#include <STC15F2K60S2.H>
#include "intrins.h"
#include <hc138_hs.H>


sbit Measure_TX = P1^0;
sbit Measure_RX = P1^1;
unsigned int distance = 0;

void Delay12us()//@12.000MHz 延时12us
{
	unsigned char i;
 
	_nop_();
	_nop_();
	i = 33;
	while (--i);
}

void Send_Wave() //产生8个40KHx超声波信号
{
	unsigned char i;
	for(i = 0; i < 8; i++)
	{
		Measure_TX = 1;
		Delay12us();	
		Measure_TX = 0;
		Delay12us();
	}
}

void Measure_Distance()	//超声波测距
{
	unsigned int time = 0;
	
	TMOD &= 0x0f;	//定时器1模式0,13位,最大8192个计数脉冲								
	TL1 = 0x00;										
	TH1 = 0x00;		
	
	Send_Wave();//发送超声波信号							
	TR1 = 1;//启动定时器						
	while((Measure_RX == 1) && (TF1 == 0));//等待超声波信号返回或者等到测量超出范围
	TR1 = 0;//停止定时器				
	
	if(TF1 == 0)//正常测量范围							
	{
		time = TH1;									
		time = (time << 8) | TL1;		
		distance = ((time / 10) * 17) / 100 + 3;//计算距离
	}
	else//超出测量范围			
	{
		TF1 = 0;
		distance = 999;
	}
}



/*    应用      */
void main(void)
{

	while(1)
	{
		
		//超声波
		Measure_Distance();//读取数据
		smg_SetOne(1,distance/100);
		smg_SetOne(2,distance%100/10);
		smg_SetOne(3,distance%10);			
		
		
	}
}

效果

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值