51单片机控制的超声波测距仪程序

作者&投稿:孟终 (若有异议请与网页底部的电邮联系)
51单片机超声波测距仪 流程图 及 程序 急求50分~

#include
#include
#define uint unsigned int
#define uchar unsigned char
#define nop _nop_()
uchar code WE0[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x80};//0x40-不带点
//unsigned char code WE1[]={0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,0x87,0xf0,0xef,0x80}; //0-9 带点
uchar code W[]={0xfe,0xfd,0xfb,0xf7} ;
unsigned char temp[3];
sbit RX=P3^4; //接受端,ECHO
sbit TX=P3^5; //控制端,TRIG
sbit wei=P2^7;
sbit duan=P2^6;
bit flag=0;
uint time=0;
uint s=0;
void delay(int xms)//延时大概x毫秒
{
int i,j;
for(i=xms;i>0;i--)
for(j=110;j>0;j--);
}
void start() //给至少10us的高电平,启动模块
{
TX=1;
nop;
nop;
nop;
nop;
nop;
nop;
nop;
nop;
nop;
nop;
nop;
nop;
nop;
nop;
TX=0;
}
uchar count()
{
time=TH0*256+TL0;
TH0=0;
TL0=0; //清零
s=(time*1.7)/100;//厘米
return s;
}
void dispros()//数据分割
{
temp[0]=s/100%10;//百位
temp[1]=s/10%10; //十位
temp[2]=s%10; //个位
}
void display() //显示函数
{
if(s>=500||s<=2) //进入盲区,溢?
{
uchar i;
s=0;
TH0=0;
TL0=0; //清零
P0=0x40;
duan=1;
duan=0;
for(i=0;i<3;i++)
{

P0=W[i];
wei=1;
wei=0;


}
}
else //正常显示
{
wei=1;
P0=0xfe;
wei=0;
duan=1;
P0= WE0[temp[0]];
delay(3);
duan=0;
wei=1;
P0=0xfd;
wei=0;
duan=1;
P0= WE0[temp[1]];
delay(2);
duan=0;
wei=1;
P0=0xfb;
wei=0;
duan=1;
P0= WE0[temp[2]];
delay(1);
}
}

void main()
{
TMOD=0X01; //定时器工作方式0
TH0=0;
TL0=0;
EA=1; //开总中断
ET0=1;//开定时器中断
while(1)
{
start();//启动模块
while(!RX); //当RX为零时等待
TR0=1; //启动计数
while(RX); //当RX为1时计数并等待
TR0=0; //关闭计数器
count(); //计数
dispros(); //处理,分割数据
display(); //显示
delay(1);
}
}

看下这个

原文http://www.elecfans.com/article/87/82/2009/20091219139294.html


基于单片机的倒车防撞预警系统设计和实现

0 引 言
汽车倒车防撞预警系统即是俗称的倒车雷达,是汽车泊车辅助装置。在汽车倒车时,倒车雷达采用超声波测距原理探测汽车尾部离障碍物的距离,当汽车尾部离障碍物的距离达到探测范围时,倒车雷达通过数码管实时动态显示距离。当汽车尾部离障碍物的距离达到设定的安全警告值时,倒车雷达发出报警声,以警示驾驶员,辅助驾驶员安全倒车。现在生产的中高档小轿车大多数都配置有倒车雷达,而出于节省成本等方面的考虑,经济型小轿车、大客车等其他车辆都没有配置倒车雷达。有市场需求的产品,必然会带动产品的开发设计。倒车雷达电路种类较多,本文介绍基于单片机控制的倒车雷达系统,该系统采用通用型单片机作为控制电路,方便系统功能扩展。系统电路主要采用集成器件构成,外围元件少,电路简洁、调试方便、成本低,利于商品化生产。


1 系统组成及工作原理
倒车防撞预警系统由四路收发一体封闭(防水)型超声波传感器及其超声波发射与回波接收电路、超声波电信号放大电路、单片机控制电路、LED数码管显示电路和蜂鸣器声音报警电路组成。系统组成框图如图1所示。



当汽车倒车时由倒车换挡装置自动接通系统电源,系统上电复位,进入工作状态。单片机编程产生一串40 kHz的矩形脉冲电压,经四选一模拟开关加到超声波发射与回波接收电路,经放大驱动超声波传感器发射出超声波,同时单片机开始计时。发射出的超声波碰到障碍物后形成反射波,部分反射波返回作用于超声波传感器,经超声波传感器的声/电转换,变成微弱的电信号,该微弱的电信号经放大、整形产生负跳变电压,向单片机发出中断申请。单片机收到中断申请的信号后,立即响应中断,执行外部中断服务程序,停止计时,得到超声波发送和返回的时间T,计算出发射点离障碍物的距离S,即:S=(C·T)/2。C是超声波在空气中的传播速度,在常温25℃时,C约为346 m/s。若发射出的超声波在测距范围内未遇到障碍物,直到单片机定时中断产生,执行定时中断服务程序,选择下一路,依次按后左路、后左中路、后右中路、后右路的顺序继续发射和接收超声波,并经过计算处理。四路探测处理完毕,选择四路中测出的最小距离值通过LED数码管显示出来。当最小距离值小于预先设定的报警距离时,单片机接通蜂鸣器的电源,蜂鸣器发出报警声。若四路探测无回波中断申请,则显示“-.--”,表明在安全距离内没有障碍物,再继续下一轮的循环探测处理。


2 系统硬件电路的设计
2.1 超声波发射与回波接收电路
超声波发射与回波接收电路的主要作用是提高驱动超声波传感器的脉冲电压幅值,有效地进行电/声转换,增大超声波的发射距离,并通过收发一体的超声波传感器将返回的超声波转变成微弱的电信号。超声波发射与回波接收电路如图2所示(画出一路,其他三路与该路一样)。



EFR40RS是收发一体封闭(防水)型超声波传感器,其中心频率f0=(40.0±1.0)kHz,-3 dB带宽1 kHz。驱动电压峰一峰值要求60~150 V。CD4052是双路四选一模拟开关,单片机的P3.4和P3.5端口输出选通信号,单片机的P3.3端口输出一串40 kHz的脉冲电压,通过CD4052的X路加到选通的开关三极管Q1基极,经脉冲变压器T1升压至100 VP-P左右,驱动超声波传感器EFR40RS发射超声波。发射时的脉冲电压幅值大小直接影响测距的远近,应采用超声波专用的脉冲变压器。反射回的超声波经原收发一体封闭型超声波传感器变成毫伏级的一串脉冲电信号。由于回波电信号的幅值小,VD3和VD4二极管截止,该信号不会通过T1变压器副边线圈形成短路。VD1和VD2二极管也截止,所以回波电信号经R1和C1,通过CD4052的Y路送到超声波电信号放大与整形电路。R1和VD1,VD2组成双向限幅电路,避免发射时的大信号造成超声波放大与整形电路阻塞,甚至损坏电路。

2.2 超声波电信号放大电路
超声波电信号放大电路采用集成电路CX20106A构成。CX20106A是日本索尼公司生产的红外遥控信号接收集成电路。通过外部所接电阻,将其内部带通滤波电路的中心频率f0设置为40 kHz,就可以接收放大超声波电信号,并整形输出负脉冲电压。
应用电路如图3所示。1脚是超声波电信号输入端,2脚与地之间连接RC串联网络,是内部前置放大电路负反馈网络的组成部分。电阻R5的数值确定前置放大电路的增益。R5电阻值减小,负反馈减弱,放大倍数增大;反之,则放大倍数减小。3脚与地之间连接检波电容C3,适当改变电容C3的大小,可以改变超声波电信号放大和整形电路的灵敏度和抗干扰能力。C3电容量大,灵敏度低,抗干扰能力强;C3容量小,灵敏度高,抗干扰能力弱,易造成误动作。5脚与电源间接入一个电阻,用以设置内部带通滤波电路的中心频率f0。





当R6=200 kΩ时,f0=40 kHz。6脚与地之间接一个积分电容,标准值为330 pF。如果该电容值取得太大,会使探测距离变短。7脚是电路集电极开路输出端,R7是该引脚的上拉电阻。集成电路CX20106A无信号输入时,7脚输出高电平,当输入的超声波电信号经放大、整形后,7脚输出一个负脉冲电压。
2.3 单片机控制电路和显示、报警电路
电路如图4所示。由于系统用到单片机的输入/输出端口不多,在不考虑功能扩展时,从功能够用和低成本的角度考虑,采用AT89C2051单片机作为控制电路的核心器件。AT89C2051单片机共有20个引脚,其中有15个I/O端口(P3.6无引出脚)。两个16位定时器/计数器,其体积小、价格低。采用12 MHz高精度的晶振,以获得较稳定的时钟频率,减小测量误差。单片机的P3.3端口周期性的输出一串40 kHz的矩形脉冲,通过双路四选一模拟开关CD4052周期性地加到四路超声波发射与回波接收电路。单片机的P3.4和P3.5端口输出双路四选一模拟开关CD4052的选通信号。单片机的P3.2端口为外部中断0中断申请信号输入端。三位LED数码管采用动态扫描显示。U4的小数点常亮,U4的单位为m,U5的单位为dm,U6的单位为cm。采用有源蜂鸣器作为报警发音器件,一是器件成本低,二是便于动态扫描显示的软件编程。



3 系统软件的设计
系统软件采用模块化设计,方便扩展移植。采用汇编语言编程。主要有主程序、T0中断服务程序、外部中断0服务程序、超声波发生子程序。

3.1 主程序
本系统有四路测距通道,采用分时工作,按后左一后左中一后右中一后右顺序循环测距。每一路发射超声波后的等待外部中断时间应大于超声波在最大有效探测距离内往返时间。所以按最大有效探测距离可以估算出最短的循环间隔时间。因为超声波在空气中传播能量会不断衰减,所以超声波测距存在最大有效探测距离。这最大有效探测距离与多种因数有关:
与超声波传感器性能的好坏、与驱动超声波传感器的脉冲电压幅值(功率)的大小、障碍物大小和形状、障碍物吸波特性以及反射波与入射波之间的夹角、与超声波放大和整形电路的灵敏度等有关。设定最大有效探测距离为8 m(收发一体封闭型超声波传感器比较难达到,实际上也没有必要探测很远的障碍物,只是设计留有裕量。由于显示位数有限,也必须对最大探测距离做限制),则循环工作的间隔时间Tm=2S/C=2×8/346A46 ms,加上避免接收超声波传感器余振的延时和程序执行时间,留足裕量,设定Tm△56 ms。
主程序流程图如图5所示。首先是对系统初始化。端口p1.0、P3.3置0;设置堆栈,中断允许总控制位EA允许中断(EA=1);允许外部中断0中断(EX0=1),采用边沿触发方式(IT0=1);设置定时器T0允许中断(ET0=1),以16位工作方式定时约56 ms;设置定时器T1以16位工作方式定时/计数,计数初值0000H,然后启动T0定时。设置显示数据初值为三位BCD码999(cm),对应字形段码显示“---”。四路探测处理完毕后,将四组数据中的最小值送入显示缓冲区,通过LED数码管显示。同时该值与设定的100 cm值比较,若四组数据中的最小值小于100 cm,P3.7端口置0,Q2三极管导通,有源蜂鸣器得电发出报警声。




由于单片机采用12 MHz的晶振,1个机器周期为1μs,所以计数器每计一个数就是1μs,定时器T1工作模式设置为16位定时/计数器模式,则其最大定时65.536 ms。由于定时器T0每56 ms产生中断,执行T0中断服务程序时停止T1计时,所以T1计时不会产生溢出中断。一轮四路探测处理完毕所用时间大约是56 ms×4=224 ms,用时很短,而倒车速度又比较慢,所以可以做到实时动态显示。
3.2 T0中断服务程序
T0中断服务程序流程图如图6所示。每隔56 ms分别按后左→后左中→后右中→后右顺序选通下一路超声波发射与回波接收电路,调用超声波发生子程序,送出16个40 kHz的超声波脉冲电压,定时器T1开始计时,定时器T0开始定时56 ms,使每路工作56 ms。



为了避免接收到超声波传感器余振的直射波产生的中断申请,延时2.8 ms后,才允许外部中断0中断,等待接收返回的超声波信号。所以,最小探测距离(盲区)Smin=Ct/2=346×0.002 8/2△0.48 m。四路探测处理完毕,将四路中最小值送入显示缓冲区。若在四路探测中有些路在有效探测范围内发射的超声波未遇障碍物,无返回波,外部中断0不产生中断申请信号,或者是进入探测盲区,外部中断0产生的中断申请不被受理,则定时器T1计时到定时器T0产生中断,在T0中断服务程序中,用三位BCD码999(三位十进制数最大值999 cm)置够四组数据。若显示缓冲区的四组数据都是999时,则对应字形段码显示“---”。倒车伊始,LED数码显示器就显示“-.--”,表明在安全距离内没有障碍物;若发出报警声后,又显示“-.--”,表明进入了探测盲区。
3.3 外部中断0服务程序
外部中断O服务程序流程图如图7所示。单片机一旦接收到返回超声波信号(即INT0引脚由高电平跳变为低电平),立即进入外部中断0服务程序。首先停止定时器T1计时,禁止外部中断0中断。然后将定时器T1中的数N,也即将超声波往返所用的时间N(单位:μs),按式S=CT/2=(346 x N×10-6)/2=173×N÷10 000计算,即得被测物的距离(单位:cm),将计算结果以百位、十位、个位BCD码方式送入比较大小的缓冲区,以备比较大小使用。然后等待定时器T0定时56 ms中断的产生,继续下一路的探测处理。



3.4 超声波发生子程序
超声波发生子程序通过P3.3端口发送16个周期是25μs(即频率40 kHz,1个周期内高电平持续13μs、低电平持续12 μs)的矩形脉冲电压。脉冲串个数在10~20个比较合适。脉冲个数太少,发射强度小,探测距离短;脉冲个数太多,发射持续时间长,在离障碍物距离近时,脉冲串尚未发射完毕,先发射出去的脉冲产生的回波就到达接收端,影响测距结果,造成测距盲区增大。


4 实现应用分析
本系统在实验室条件下进行了可行性的研究设计,要实际应用中就必须考虑测量精度和工作稳定性的问题。因此,本系统可采取几项措施来提高测量精度和工作稳定性。
(1)超声波的传播速度与温度有关。为了适应不同环境温度下的测距需要,提高测量精度,硬件电路上可增加检测车外环境温度的环节。单片机根据实测的温度值,再计算确定超声波的传播速度,即C=331.4+0.6lt。t是环境温度。或者在不增加硬件成本情况下,可考虑通过实验数据分析,找到测量值与实际值偏差特点和规律,通过软件编程对测量数据进行校正处理。
(2)软件设计中采用数字滤波中的算术平均滤波程序对每个测距点进行连续多次测量,取平均值作为该测距点的测量数据,以提高数据采样的可靠性。要尽量减小探测盲区,所设定的延时时间可根据实际所用超声波传感器余振时间而定,可在实际调试中确定最小延时时间。
(3)倒车雷达安装在车上,倒车雷达的工作环境非常恶劣,汽车倒车工作时,高压点火产生很强的电磁辐射,会影响电路正常工作。所以在硬件及软件方面要考虑采取抗干扰措施,提高系统工作的可靠性。如用金属壳屏蔽电路,采用屏蔽线连接超声波传感器;在满足测量距离的情况下,可适当调大超声波电信号放大和整形电路中检波电容C3的容量。硬件上可增加“看门狗”电路,软件设计添加指令冗余、软件陷阱、或设置软件“看门狗”,防止程序“跑飞”或者进入死循环。对于驾驶员来说,倒车时主要关心的是车后方有无障碍物、以及障碍物离车大约有多远等问题。由于车子制动时存在惯性,倒车遇到障碍物时,驾驶员总要提前制动。考虑性价比,倒车雷达测量精度不必很高。但从倒车安全考虑,此时的测量显示值宁大勿小。


5 结 语
本系统充分利用了单片机的内部资源,用软件编程产生超声波矩形脉冲,代替硬件的超声波发生电路,节省了硬件成本。采用一块集成器件实现超声波接收放大和整形,避免了采用多级集成运放组成高增益放大电路易产生自激等问题。实验表明设计可行。在不增加硬件成本时,通过完善软件设计,可提高系统测量精度和工作的可靠性,能够满足使用要求。在考虑功能扩展时,可以采用带“看门狗”的AT89S52单片机,以增加扩展端口。在超声波测距的基础上,如可增加防盗报警功能、车载蓄电池电压检测功能等,若增加微型摄像头和小型液晶显示器,便成为可直接观察车后方的可视倒车雷达。本系统实用性强,性价比高。

希望对你有帮助
//超声波模块显示程序
#include <reg52.h> //包括一个52标准内核的头文件
#define uchar unsigned char //定义一下方便使用
#define uint unsigned int
#define ulong unsigned long
sbit Tx = P3^3; //产生脉冲引脚
sbit Rx = P3^2; //回波引脚
uchar code SEG7[10]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90};//数码管0-9
uint distance[4]; //测距接收缓冲区
uchar ge,shi,bai,temp,flag,outcomeH,outcomeL,i; //自定义寄存器
bit succeed_flag; //测量成功标志
//********函数声明
void conversion(uint temp_data);
void delay_20us();
void pai_xu();
void main(void) // 主程序
{ uint distance_data,a,b;
uchar CONT_1;
i=0;
flag=0;
Tx=0; //首先拉低脉冲输入引脚
TMOD=0x11; //定时器0,定时器1,16位工作方式
TR0=1; //启动定时器0
IT0=0; //由高电平变低电平,触发外部中断
ET0=1; //打开定时器0中断
EX0=0; //关闭外部中断
EA=1; //打开总中断0

while(1) //程序循环
{
EA=0;
Tx=1;
delay_20us();
Tx=0; //产生一个20us的脉冲,在Tx引脚
while(Rx==0); //等待Rx回波引脚变高电平
succeed_flag=0; //清测量成功标志
EX0=1; //打开外部中断
TH1=0; //定时器1清零
TL1=0; //定时器1清零
TF1=0; //
TR1=1; //启动定时器1
EA=1;

while(TH1 < 30);//等待测量的结果,周期65.535毫秒(可用中断实现)
TR1=0; //关闭定时器1
EX0=0; //关闭外部中断

if(succeed_flag==1)
{
distance_data=outcomeH; //测量结果的高8位
distance_data<<=8; //放入16位的高8位
distance_data=distance_data|outcomeL;//与低8位合并成为16位结果数据
distance_data*=12; //因为定时器默认为12分频
distance_data/=58; //微秒的单位除以58等于厘米
} //为什么除以58等于厘米, Y米=(X秒*344)/2
// X秒=( 2*Y米)/344 ==》X秒=0.0058*Y米 ==》厘米=微秒/58
if(succeed_flag==0)
{
distance_data=0; //没有回波则清零

}

distance[i]=distance_data; //将测量结果的数据放入缓冲区
i++;
if(i==3)
{
distance_data=(distance[0]+distance[1]+distance[2]+distance[3])/4;
pai_xu();
distance_data=distance[1];

a=distance_data;
if(b==a) CONT_1=0;
if(b!=a) CONT_1++;
if(CONT_1>=3)
{ CONT_1=0;
b=a;
conversion(b);
}
i=0;
}
}
}
//***************************************************************
//外部中断0,用做判断回波电平
INTO_() interrupt 0 // 外部中断是0号
{
outcomeH =TH1; //取出定时器的值
outcomeL =TL1; //取出定时器的值
succeed_flag=1; //至成功测量的标志
EX0=0; //关闭外部中断
}
//****************************************************************
//定时器0中断,用做显示
timer0() interrupt 1 // 定时器0中断是1号
{
TH0=0xfd; //写入定时器0初始值
TL0=0x77;
switch(flag)
{case 0x00:P0=ge; P2=0x7f;flag++;break;
case 0x01:P0=shi;P2=0xbf;flag++;break;
case 0x02:P0=bai;P2=0xdf;flag=0;break;
}
}

//显示数据转换程序
void conversion(uint temp_data)
{
uchar ge_data,shi_data,bai_data ;
bai_data=temp_data/100 ;
temp_data=temp_data%100; //取余运算
shi_data=temp_data/10 ;
temp_data=temp_data%10; //取余运算
ge_data=temp_data;

bai_data=SEG7[bai_data];
shi_data=SEG7[shi_data]&0x7f;
ge_data =SEG7[ge_data];

EA=0;
bai = bai_data;
shi = shi_data;
ge = ge_data ;
EA=1;
}
//******************************************************************

void delay_20us()
{ uchar bt ;
for(bt=0;bt<60;bt++);
}
void pai_xu()
{ uint t;
if (distance[0]>distance[1])
{t=distance[0];distance[0]=distance[1];distance[1]=t;}
if(distance[0]>distance[2])
{t=distance[2];distance[2]=distance[0];distance[0]=t;}
if(distance[1]>distance[2])
{t=distance[1];distance[1]=distance[2];distance[2]=t;}
}

是注释的话加//
意思是根据主频换算定时器装入值,最好不要浮点数...

思路到是有,一个是用定时计数器计时,另一个外部中断计算脉冲个数,然后显示就可以了,我以前搞过,现在找不到了!!

淘宝上买超声波模块的页面有下载连接
你就加个LED就行了。

我刚好也是做这个的


一个单片机同时控制三个超声波测距模块,程序怎样实现呢?
只不过是单片机上接了三个模块,是不可能同时控制的,写程序时,分别对三个模块进行测量,因单片机的速度是非常快的,从外观上看就好像是同时测量的,可程序是不可能同时执行的,只是互相间隔的时间极短,表面上就同时了。确切说,从微观上是分时控制,从宏观上看是同时了。

如何用一片51单片机控制3个超声波us-100
你 用电平触发方式,把3个us-100的触发引脚分别接3个IO端口,把返回引脚连在一起,接在外部中断输入脚上;3个IO口分别输出触发信号,返回的就是各自的距离数据。

单片机怎样使用超声波传感器?
VCC GND是电源,TRIG是控制端(输入),ECHO是返回端(输出)。VCC GND外接电源正负极给传感器供电,TRIG、ECHO接单片机AT89C52的I\/O端口,具体接哪个端口要根据电路和单片机内的程序设定来确定。大致的过程是单片机给TRIG所接端口个高电平脉冲,超声波发射模块SR40开始发送超声波,当收到反射波的时候,EC...

关于用单片机控制超声波测距模块的问题
这可能是你的超声波模块设计就如此.模块在发射超声波时输出高电平,在接收到反射信号后,将输出复位成低电平。这个高电平时间就是超声波在某块与障碍物之间往返一次所需的时间。当无障碍物时,高电平会无限期延续下去,这样就无法启动下一个超声波发送,必须在经过一个特定的时间后,强制复位。这个时间...

51单片机最多可以控制几个超声波模块?
有几个外部中断脚就能控制几个,只用一个定时计数器当然只控一个最好了,你要想控制几个当然也可以,做延时跟标志位,让它们进队列一个一个处理超声波模块的数据,这样就没有及时性了,没什么意义...

单片机:随便解释下超声波时序图。有图的
单片机发出40 kHz 的方波信号,经放大后通过超声波发射器输出;超声波接收器将接收到的超声波信号经放大器放大,用锁相环电路进行检波处理后,启动单片机中断程序,测得时间为t.再通过软件编程进行判别、计算,得出所测距离值 发射器发出的超声波以速度v 在空气中传播,在到达被测物体时被反射返回,由...

51单片机控制的超声波测距程序问题,为什么num一直为0
嗯!这个问题是!你的外部中断使用的是外部中断0,而定时器使用的也是0.在51内,外部中断0的优先级是要大于定时器0的。所以在程序的最后是要先执行外部中断0的!然后你的程序就会先进入外部中断服务,然后你在外部中断中又把定时器中断给关闭了!这样你就不会走到定时器中断的服务项中。所以你的num...

请教各位大神用51单片机keil软件编程超声波测距模块需要了解哪些程序我...
这个主要看你买的超声波模块了,一般这个模块能够自动发送和接收超声波,但是启动这个模块需要满足一定时序,当接收到数据以后,会产生中断,通知MCU。可以通过计时达到测距目的。s = vt(t=T\/2,因为一个来回),v = 340m\/s

单片机控制超声波做蔽障程序总是卡死为何!运行后电机动一下就,程序就...
首先你看一下电机工作以后,对单片机供电相关的电源有多大影响,也就是对比电机不转和转起来这些电源的压降以及纹波,看是否在spec之内;(2)、软件部分。你可以单步调试,看程序跑到哪里跑飞了。具体方法可以用指示灯方式,比如LED或者数码管显示。最好的用串口工具打印信息。如还有其他问题,再联系!

1 无源蜂鸣器用单片机控制,最高能发出多高频率的声,有上限没 2 蜂鸣器...
蜂鸣器可发出高至超声波的声音,当然,超声波不为一般人所听到。所以说,你可不必考虑声音上限,或者将超声波下限20kHz作为频率上限即可。蜂鸣器发出声音大小与电流有关,但是一般蜂鸣器所需电流很小,如果输出功率足够的话,主要与输出电压相关,一般加一个9012之类就足够了,电压按蜂鸣器标称取。某些频率的...

和田地区19214242691: 51单片机超声波测距的一段代码 -
彩垄二十: 关键这个电路是硬件设计好就可以.做一个40KHz的发射电路...用2051的一个IO控制电源...动态扫描LED显示 另外再做一个40KHZ的接收电路...二者频率对准...接收电路接收到发射信号的时候输出一个电压触发中断,先接通...

和田地区19214242691: 求US - 100(模块)超声波测距的C语言程序,基于51单片机的,3Q哦~ -
彩垄二十: #include <reg51.h>#define uchar unsigned char #define uint unsigned int unsigned char code smg[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e,0x00}; sbit tr=P1^0; sbit ec=P1^1; uint distance,time,tl,th; ...

和田地区19214242691: 用51单片机实现超声波测距怎样才可以测到4m? -
彩垄二十: 输出用并联门电路驱动,如CD4069,以增大输出电流. 接收采用低噪声运放,如NE5532,放大1000倍. 采用接收,发射分开的探头 超声波测距系统的软件设计,由于超声发射传感器与超声接收传感器相隔很近,当发射超声波时,接收传感...

和田地区19214242691: 51单片机,用超声波模块测距,C语言怎样写才能使当测得距离小于7时P1^1口输出高电平,大于7时输出高电平
彩垄二十: 用if 和 else 语句就可以了. if(CSB_SCAN() &lt;= 7) P1^1 = 1; else P1^1 = 0; CSB_SCAN()是获得超声波距离的带返值函数,另外测得的单位要注意.

和田地区19214242691: 51单片机 HC - SR04超声波测距 我写的C语言代码,请问 -
彩垄二十: 1、HC-SR04使用方法:给触发端子trig一个10us以上的高电平即可触发,触发后echo端子将接受到高电平,高电平的持续时间就是测距的往返时间.2、例程:#include<reg52.h>#define uchar unsigned char#define uint unsigned int/*位定义*/ ...

和田地区19214242691: 51单片机测距编程(c语言) -
彩垄二十: 有个测距的程序,但是输出是数码管显示的,然后报警输出是蜂鸣器的,根据具体改变发声频率网页链接

和田地区19214242691: 51单片机 超声波测距模块 想编一个当距离达到一定大的时候能输出一个信号的程序 求指教
彩垄二十: 不知道这个超声波模块具体是如何工作的,一般理解“当距离大到一定大的时候”,是指当在这个“一定大的距离”测到物体了.那么你就处理这个距离为多少的时候,触发一个程序,这个程序就输出一个信号.

和田地区19214242691: 用AT89C51单片机做超声波测距
彩垄二十: 给你贴一个吧,显示部分的代码你需要修改一下(因为这个代码里面的数码管显示用不到段选位选) //超声波模块显示程序 #include &lt;reg52.h&gt; //包括一个52标准内核的头文件 #define uchar unsigned char //定义一下方便使用 #define uint ...

和田地区19214242691: 51单片机超声波测距1602显示 -
彩垄二十: 以前做了一个数码管显示的超声波测距,你可以参考一下: #include<reg51.h> #include<intrins.h> #define uchar unsigned char #define uint unsigned int uchar code ledtab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//0-9 uchar scanled...

和田地区19214242691: 单片机超声波测距系统程序(计算部分) -
彩垄二十: 根据时间算出距离,看距离是否超限,超出测量范围显示“-”,否则显示距离,再把距离跟设定值比较,大于报警值报警.MODE=0,显示测量值,否则显示报警值

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网