11.1蜂鸣器
1.蜂鸣器介绍
蜂鸣器是一种将电信号转换为声音信号的器件,常服务器托管网用来产生设备的按键音、报警音等提示信号
蜂鸣器按驱动方式可分为有源蜂鸣器和无源蜂鸣器
有源蜂鸣器:内部自带振荡源,将正负极接上直流电压即可持续发声,频率固定
无源蜂鸣器:内部不带振荡源,需要控制器提供振荡脉冲才可发声,调整提供振荡脉冲的频率,可发出不同频率的声音
本开发板使用的是无源蜂鸣器
2.常用驱动电路
不能直接用IO口驱动蜂鸣器,因为蜂鸣器所需的电流较大,直接用IO口一般不足以提供相应的电流,需要放大电路。
1.三极管驱动(大多数情况下都用三极管来驱动)
2.集成电路驱动(本开发板使用)
蜂鸣器
ULN2003是高耐压、大电流达林顿陈列,由七个硅NPN达林顿管组成。
ULN2003逻辑框图如下:
对应IO口直接有个非门,也就是说如果1号口输入1,则16号口输出0。相应的P25输入1,BEEP输出0。
因为使用的是无源蜂鸣器,所以BEEP口需要输入脉冲信号,而不是简单的高电平或者低电平
Buzzer.c
#include
#include
//蜂鸣器端口:
sbit Buzzer=P2^5;
/**
* @brief 蜂鸣器私有延时函数,延时500us
* @param 无
* @retval 无
*/
void Buzzer_Delay500us() //@12.000MHz
{
unsigned char i;
_nop_();
i = 247;
while (--i);
}
/**
* @brief 蜂鸣器发声
* @param ms 发声的时长,范围:0~32767
* @retval 无
*/
void Buzzer_Time(unsigned int ms)
{
unsigned int i;
for(i=0;ims*2;i++)
{
Buzzer=!Buzzer;
Buzzer_Delay500us();
}
}
Buzzer.h
#ifndef __BUZZER_H__
#define __BUZZER_H__
void Buzzer_Time(unsigned int ms);
#endif
main.c
#include
#include "Delay.h"
#include "Key.h"
#include "Nixie.h"
#include "Buzzer.h"
unsigned char KeyNum;
void main()
{
Nixie(1,0);
while(1)
{
KeyNum=Key();
if(KeyNum)
{
Buzzer_Time(100);
Nixie(1,KeyNum);
}
}
}
现象:按下按键1-4,第一个数码管会显示1-4
注意:按下按键时可能会出现数码管闪一次就熄灭的情况,将NixieShowNum函数的最后两行删除即可
蜂鸣器标准的频率是1000Hz,所以可以延迟500us,通过STC-ISP软件生成500us的延时函数
服务器托管,北京服服务器托管网务器托管,服务器租用 http://www.fwqtg.net
相关推荐: ASP.NET Core Web API下基于Keycloak的多租户用户授权的实现
在上文《Keycloak中授权的实现》中,以一个实际案例介绍了Keycloak中用户授权的设置方法。现在回顾一下这个案例: 服务供应商(Service Provider)发布/WeatherForecast API供外部访问 在企业应用(Client)里有三个…