STM32CubuMx超声波测距




       代码如下:

#define Trig_L HAL_GPIO_WritePin(GPIOD, GPIO_PIN_6, 0);
#define Trig_H HAL_GPIO_WritePin(GPIOD, GPIO_PIN_6, 1);

void delay_us(uint16_t us)//微秒延迟函数
{
   uint16_t i=0xffff-us-5;
    __HAL_TIM_SET_COUNTER(&htim3,i);
    HAL_TIM_Base_Start(&htim3);
       
    while(i<0xffff-5)
    {
       i=__HAL_TIM_GET_COUNTER(&htim3);
    }
    HAL_TIM_Base_Stop(&htim3);
}
void Set_Trig()//触发超声波函数
{
    Trig_L;
    Trig_H;
    delay_us(20);
//     HAL_Delay(1);
    Trig_L;
}

void HAL_GPIO_EXTI_Callback(uint16_t a)//外部中断中断处理函数替代void EXTI9_5_IRQHandler(void)
{
      float distance;
      static float cnt=0;    
    
   if(HAL_GPIO_ReadPin(GPIOD, Echo_Pin)==1)//Echo引脚为低电平则停在此处循环
    {  
        HAL_TIM_Base_Start(&htim2);                 //开启定时器
        __HAL_TIM_SetCounter(&htim2,0);              //清空定时器的值
    }
    if(HAL_GPIO_ReadPin(Echo_GPIO_Port, Echo_Pin)==0)
    { 
        HAL_TIM_Base_Stop(&htim2);                  // 停止定时器
        cnt=__HAL_TIM_GetCounter(&htim2);           //获取当前计数值

        distance= cnt*340.0/2*0.000001*100;
        printf("%.3fcm\r\n",distance);
        cnt=0;
    }
    
}

主函数:

int main(void)
{

 while (1)
  {
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
      
    int SR04_tick = 0;    
   
    if(HAL_GetTick() - SR04_tick > 50)/*滴答定时器50ms发射一次超声波*/
    {
        SR04_tick = HAL_GetTick();
        Set_Trig();
    }
   }
}


 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值