找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3043|回复: 4
收起左侧

stm32超声波源码分享

[复制链接]
ID:222379 发表于 2017-7-25 19:03 | 显示全部楼层 |阅读模式
超声波资料分享

  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)

回复

使用道具 举报

ID:169559 发表于 2017-7-26 11:36 | 显示全部楼层
谢谢分享!
回复

使用道具 举报

ID:309115 发表于 2019-7-6 09:46 | 显示全部楼层
谢谢楼主分享
回复

使用道具 举报

ID:696129 发表于 2020-3-9 15:52 | 显示全部楼层
谢谢楼主
回复

使用道具 举报

ID:574873 发表于 2020-3-10 15:17 | 显示全部楼层
谢谢楼主分享,好人呀
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表