目录
原理
蜂鸣器按驱动方式可分为有源蜂鸣器和无源蜂鸣器
有源蜂鸣器:内部自带震荡源,将正负极接上直流电压及可持续发声,频率固定。
无源蜂鸣器:内部不带震荡源,需要控制器提供震荡脉冲才可发声,调整提供震荡脉冲的频率,可发出不同频率的声音。
蜂鸣器有+为正极,若无符号,则长引脚为正极。
驱动方式
可以直接只用IO接蜂鸣器负极直接驱动,但是单片机提供的功率较小,可以使用三极管进行驱动。
因为 51 单片机 I0 口的驱动能力较弱(即使外接上拉电阻),而蜂鸣器驱动需要约 30mA,所以非常困难即使可以驱动,那对于整个芯片的其 I0 剩下驱动能力就更加弱甚至无法工作。所以我们不会直接使用 I0 口驱动蜂鸣器,而是通过三极管把电流放大后再驱动蜂鸣器,这样 51 单片机的 I0 口只需要提供不到 1mA 的电流就可控制蜂鸣器。所以我们也经常说到 51单片机芯片是用来做控制的,而不是驱动。
开发板上使用的是无源蜂鸣器,它需要一定频率的脉冲(高低电平)才会发声,当P15 端子有一个高电平进来时,PNP 三极管 几级截止,蜂鸣器不得电当P15 端子有一个低电平进来时,PNP 三极管 几极 导通,蜂鸣器得电,如果 J7 端子有一个一定频率的脉冲信号(高低电平不断翻转)时,无源蜂鸣器发出声音 。
一个周期反转两次,在12分频的单片机下,机器的周期是振荡周期的十二分之一。
代码展示(按键提示音)
#include <REGX52.H>
#include "Delay.h"
#include "Key.h"
#include "Nixie.h"
#include "Buzzer.h"
sbit Buzzer=P2^5;
void Buzzer_Delay500us() //@11.0592MHz
{
unsigned char i;
_nop_();
i = 227;
while (--i);
}
void Buzzer_Time(unsigned int ms)
{
unsigned int i;
for(i=0;i<ms*2;i++)
{
Buzzer=!Buzzer;
Buzzer_Delay500us();
}
}
unsigned char NixieTable[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x77,0x7C,0x39,0x5E,0x79,0x71,0x00};
void Nixie(unsigned char Location,Number)
{
switch(Location)
{
case 1:P2_4=0;P2_3=0;P2_2=0;break;
case 2:P2_4=0;P2_3=0;P2_2=1;break;
case 3:P2_4=0;P2_3=1;P2_2=0;break;
case 4:P2_4=0;P2_3=1;P2_2=1;break;
case 5:P2_4=1;P2_3=0;P2_2=0;break;
case 6:P2_4=1;P2_3=0;P2_2=1;break;
case 7:P2_4=1;P2_3=1;P2_2=0;break;
case 8:P2_4=1;P2_3=1;P2_2=1;break;
}
P0=NixieTable[Number];
//Delay(1);
}
void Delay(unsigned char xms) //@11.0592MHz
{
unsigned char i, j;
while(xms--)
{
i = 2;
j = 199;
do
{
while (--j);
} while (--i);
}
}
unsigned char Key()
{
unsigned char KeyNumber=0;
if(P3_1==0){Delay(20);while(P3_1==0);Delay(20);KeyNumber=1;}
if(P3_0==0){Delay(20);while(P3_0==0);Delay(20);KeyNumber=2;}
if(P3_2==0){Delay(20);while(P3_2==0);Delay(20);KeyNumber=3;}
if(P3_3==0){Delay(20);while(P3_3==0);Delay(20);KeyNumber=4;}
return KeyNumber;
}
unsigned char KeyNum;
void main()
{
Nixie(8,0);
while(1)
{
KeyNum=Key();
if(KeyNum)
{
Buzzer_Time(1000);
Nixie(8,KeyNum);
}
}
}
- 注意:新版普中板子中蜂鸣器的IO口是P2^5