標(biāo)題: stm32超聲波源碼分享 [打印本頁]

作者: lan2017    時間: 2017-7-25 19:03
標(biāo)題: 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 開發(fā)板
  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)                /* 關(guān)閉總中斷 */  
  21. #define SEI() __set_PRIMASK(0)                /*開總中斷*/

  22. void Delay(unsigned short int time);  //粗略的延時函數(shù)
  23. float ChangeDistance(unsigned int cout1);  //時間轉(zhuǎn)為距離函數(shù)
  24. //ECHO PA4
  25. //TRIG PA5
  26. /**
  27.   * @brief  主函數(shù)
  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();  //測距模塊對應(yīng)的引腳初始化
  39.     CLI() ;//關(guān)閉總中斷
  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的計數(shù)器清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(" 當(dāng)前距離為:%f\n",distance);
  67.                           Delay(20000);
  68.                                 Delay(20000);
  69.                           while(1);
  70.                                
  71.      }
  72. }

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

  81. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復(fù)制代碼

全部資料下載地址:
超聲波測距模塊.rar (3.05 MB, 下載次數(shù): 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.torrancerestoration.com/bbs/) Powered by Discuz! X3.1