找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2053|回复: 0
打印 上一主题 下一主题
收起左侧

STM32F103VET6超声波测距源码

[复制链接]
跳转到指定楼层
楼主
ID:494791 发表于 2019-8-6 08:35 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
模块名称:HY-SRF05
工作原理:给TRIG引脚至少10us高电平后,该模块立即发出8个40KHZ的方波,之后,ECHO引脚立马变为高电平,发出的方波返回后,ECHO引脚变为低电平,因此,测量距离的关键即为测量ECHO引脚高电平时间,我试了延时和定时器两种 ,输入捕获应该也可以
核心代码,定时器版本
float Hcsr04GetLength(void )
{
                    int i = 0;
                                int t=0;
        float lengthTemp = 0;
        float sum = 0;
        while(i!=5)
        {
                                        TRIG_Send = 1;      //发送口高电平输出
                                        delay_us(20);
                                        TRIG_Send = 0;
                                        while(ECHO_Reci == 0);      //等待接收口高电平输出
                                        OpenTimerForHc();        //打开定时器                        
                                        while(ECHO_Reci == 1);
                                        CloseTimerForHc();        //关闭定时器        
                                        i = i + 1;
                                        t = GetEchoTimer();        //获取时间,分辨率为1US
                                        lengthTemp = ((float)t/58.0);//cm
                                         sum = lengthTemp + sum ;
        }

        lengthTemp = sum/5.0;
        return lengthTemp;
}

延时版本
float Hcsr04GetLength(void)
{
        u32 t = 0;
        int i = 0;
        float lengthTemp = 0;
        float sum = 0;
        while(i!=5)
        {
                                        t=0;
                                        ECHO_Reci=0;
                                        TRIG_Send = 1;      //发送口高电平输出
                                        delay_us(10);
                                        TRIG_Send = 0;
                                        while(ECHO_Reci == 0);      //等待接收口高电平输出
                                        while(ECHO_Reci==1)
                                        {
                                                 delay_us(1);//精度
                                                 t++;
                                        }
                                        i = i + 1;               
                                        lengthTemp = ((float)t/58);//cm
                                        sum = lengthTemp + sum ;
        }
        lengthTemp = sum/5.0;
        return lengthTemp;
}

完整代码已打包为一个压缩包 01.7z (186.74 KB, 下载次数: 48)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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