标题: stm32超声波源码分享 [打印本页]

作者: lan2017    时间: 2017-7-25 19:03
标题: stm32超声波源码分享
超声波资料分享

  1. /**
  2.   ******************************************************************************
  3.   * @file    main.c
  4.   * @author  fire
  5.   * @version V1.0
  6.   * @date    2013-xx-xx
  7.   * @brief   USART printf example
  8.   ******************************************************************************
  9.   * @attention
  10.   *
  11.   * 实验平台:野火 iSO STM32 开发板
  12.   *
  13.   ******************************************************************************
  14.   */
  15.   
  16. #include "stm32f10x.h"
  17. #include "bsp_usart1.h"
  18. #include "bsp_length.h"
  19. #include "bsp_tick.h"

  20. #define CLI()      __set_PRIMASK(1)                /* 关闭总中断 */  
  21. #define SEI() __set_PRIMASK(0)                /*开总中断*/

  22. void Delay(unsigned short int time);  //粗略的延时函数
  23. float ChangeDistance(unsigned int cout1);  //时间转为距离函数
  24. //ECHO PA4
  25. //TRIG PA5
  26. /**
  27.   * @brief  主函数
  28.   * @param  无
  29.   * @retval 无
  30.   */
  31. int main(void)
  32. {
  33.           unsigned int count=0;
  34.           float distance=0;
  35.           float distancebuf[]={0};
  36.                 /* USART1 config 115200 8-N-1 */
  37.                 USART1_Config();
  38.     Distance_Config();  //测距模块对应的引脚初始化
  39.     CLI() ;//关闭总中断
  40.           SEI(); //开总中断
  41.           Tim3_Config();  //定时器的初始化
  42.        
  43.           
  44.           GPIO_ResetBits(GPIOA,GPIO_Pin_5);  //先拉低电平
  45.        
  46.           while(1)
  47.                 {
  48.       //  printf("测距开始\n");
  49.                           GPIO_SetBits(GPIOA,GPIO_Pin_5);  //拉高电平
  50.                           Delay(30);  //延时20个微秒
  51.                         //  Delay(20);
  52.                         //  Delay(20);
  53.                          GPIO_ResetBits(GPIOA,GPIO_Pin_5);

  54.        TIM3->CNT=0;  //TIM3的计数器清0

  55.        while(GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_4) == 0); //等待ECHO的高电平
  56.                

  57.        TIM_Cmd(TIM3,ENABLE);  //运行TIM3进行计时
  58.       
  59.                         while((GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_4) == 1) && (TIM3->CNT < TIM3->ARR-10));
  60.                          
  61.                           TIM_Cmd(TIM3,DISABLE);  
  62.                       
  63.         count=TIM3->CNT;

  64.         printf("count=%d",count);                       
  65.                           distance=ChangeDistance(count);
  66.                           printf(" 当前距离为:%f\n",distance);
  67.                           Delay(20000);
  68.                                 Delay(20000);
  69.                           while(1);
  70.                                
  71.      }
  72. }

  73. void Delay(unsigned short int time)  //粗略的延时函数
  74. {
  75.     unsigned char i=0;
  76.           while(time--)
  77.                 {
  78.         i=10;
  79.                           while(i--);
  80. ……………………

  81. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

全部资料下载地址:
超声波测距模块.rar (3.05 MB, 下载次数: 65)


作者: sfd123    时间: 2017-7-26 11:36
谢谢分享!
作者: linouba    时间: 2019-7-6 09:46
谢谢楼主分享
作者: 无踪雪    时间: 2020-3-9 15:52
谢谢楼主
作者: fengyu1352    时间: 2020-3-10 15:17
谢谢楼主分享,好人呀




欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1