單片機蜂鳴器的控制程序與驅動電路圖

2021-02-13 21ic電子網

蜂鳴器從結構區分分為壓電式蜂鳴器和電磁式蜂鳴器。壓電式為壓電陶瓷片發音,電流比較小一些,電磁式蜂鳴器為線圈通電震動發音,體積比較小。

按照驅動方式分為有源蜂鳴器和無源蜂鳴器。這裡的有源和無源不是指電源,而是振蕩源。有源蜂鳴器內部帶了振蕩源,如圖1中所示,給了 BUZZ 引腳一個低電平,蜂鳴器就會直接響。而無源蜂鳴器內部是不帶振蕩源的,要讓他響必須給 500Hz~4.5KHz 之間的脈衝頻率信號來驅動它才會響。有源蜂鳴器往往比無源蜂鳴器貴一些,因為裡邊多了振蕩電路,驅動發音也簡單,靠電平就可以驅動,而無源蜂鳴器價格比較便宜,此外無源蜂鳴器聲音頻率可以控制,而音階與頻率又有確定的對應關係,因此就可以做出來「do re mi fa sol la si」的效果,可以用它製作出簡單的音樂曲目,比如生日歌、兩隻老虎等等。

 

 

圖1  蜂鳴器電路原理圖

 

我們來看一下圖1的電路,蜂鳴器電流依然相對較大,因此需要用三極體驅動,並且加了一個 100 歐的電阻作為限流電阻。此外還加了一個 D4 二極體,這個二極體叫做續流二極體。我們的蜂鳴器是感性器件,當三極體導通給蜂鳴器供電時,就會有導通電流流過蜂鳴器。而我們知道,電感的一個特點就是電流不能突變,導通時電流是逐漸加大的,這點沒有問題,但當關斷時,經「電源-三極體-蜂鳴器-地」這條迴路就截斷了,過不了任何電流了,那麼儲存的電流往哪兒去呢,就是經過這個 D4 和蜂鳴器自身的環路來消耗掉了,從而就避免了關斷時由於電感電流造成的反向衝擊。接續關斷時的電流,這就是續流二極體名稱的由來。

蜂鳴器經常用於電腦、印表機、萬用表這些設備上做提示音,提示音一般也很簡單,就是簡單發出個聲音就行,我們用程序簡單做了個 4KHZ 頻率下的發聲和 1KHZ 頻率下的發聲程序,同學們可以自己研究下程序,比較下實際效果。

#include

sbit BUZZ = P1^6; //蜂鳴器控制引腳

unsigned char T0RH = 0; //T0 重載值的高字節

unsigned char T0RL = 0; //T0 重載值的低字節

void OpenBuzz(unsigned int frequ);

void StopBuzz();

void main(){

unsigned int i;

TMOD = 0x01; //配置 T0 工作在模式 1,但先不啟動

EA = 1;

while (1){ //使能全局中斷

OpenBuzz(4000); //以 4KHz 的頻率啟動蜂鳴器

for (i=0; i<40000; i++);

StopBuzz(); //停止蜂鳴器

for (i=0; i<40000; i++);

OpenBuzz(1000); //以 1KHz 的頻率啟動蜂鳴器

for (i=0; i<40000; i++);

StopBuzz(); //停止蜂鳴器

for (i=0; i<40000; i++);

}

}

/* 蜂鳴器啟動函數,frequ-工作頻率 */

void OpenBuzz(unsigned int frequ){

unsigned int reload;//計算所需的定時器重載值

reload = 65536 - (11059200/12)/(frequ*2); //由給定頻率計算定時器重載值

T0RH = (unsigned char)(reload >> 8); //16 位重載值分解為高低兩個字節

T0RL = (unsigned char)reload;

TH0 = 0xFF; //設定一個接近溢出的初值,以使定時器馬上投入工作

TL0 = 0xFE;

ET0 = 1; //使能 T0 中斷

TR0 = 1; //啟動 T0

}

/* 蜂鳴器停止函數 */

void StopBuzz(){

ET0 = 0; //禁用 T0 中斷

TR0 = 0; //停止 T0

}

/* T0 中斷服務函數,用於控制蜂鳴器發聲 */

void InterruptTimer0() interrupt 1{

TH0 = T0RH; //重新加載重載值

TL0 = T0RL;

BUZZ = ~BUZZ; //反轉蜂鳴器控制電平

}

另外用蜂鳴器來輸出音樂,僅僅是好玩而已,應用很少,裡邊包含了音階、樂譜的相關內容,程序也有一點複雜,所以就不詳細給大家去講解了。僅提供一個可以播放《兩隻老虎》的程序,大家可以下載到板子上玩玩,滿足一下好奇心。

#include

sbit BUZZ = P1^6; //蜂鳴器控制引腳

unsigned int code NoteFrequ[] = { //中音 1-7 和高音 1-7 對應頻率列表

523, 587, 659, 698, 784, 880, 988, //中音 1-7

1047, 1175, 1319, 1397, 1568, 1760, 1976 //高音 1-7

};

unsigned int code NoteReload[] = { //中音 1-7 和高音 1-7 對應的定時器重載值

65536 - (11059200/12) / (523*2), //中音 1

65536 - (11059200/12) / (587*2), //2

65536 - (11059200/12) / (659*2), //3

65536 - (11059200/12) / (698*2), //4

65536 - (11059200/12) / (784*2), //5

65536 - (11059200/12) / (880*2), //6

65536 - (11059200/12) / (988*2), //7

65536 - (11059200/12) / (1047*2), //高音 1

65536 - (11059200/12) / (1175*2), //2

65536 - (11059200/12) / (1319*2), //3

65536 - (11059200/12) / (1397*2), //4

65536 - (11059200/12) / (1568*2), //5

65536 - (11059200/12) / (1760*2), //6

65536 - (11059200/12) / (1976*2), //7

};

bit enable = 1; //蜂鳴器發聲使能標誌

bit tmrflag = 0; //定時器中斷完成標誌

unsigned char T0RH = 0xFF; //T0 重載值的高字節

unsigned char T0RL = 0x00; //T0 重載值的低字節

void PlayTwoTiger();

void main(){

unsigned int i;

EA = 1; //使能全局中斷

TMOD = 0x01; //配置 T0 工作在模式 1

TH0 = T0RH;

TL0 = T0RL;

ET0 = 1; //使能 T0 中斷

TR0 = 1; //啟動 T0

while (1){

PlayTwoTiger(); //播放樂曲--兩支老虎

for (i=0; i<40000; i++); //停止一段時間

}

}

/* 兩支老虎樂曲播放函數 */

void PlayTwoTiger(){

unsigned char beat; //當前節拍索引

unsigned char note; //當前節拍對應的音符

unsigned int time = 0; //當前節拍計時

unsigned int beatTime = 0; //當前節拍總時間

unsigned int soundTime = 0; //當前節拍需發聲時間

//兩隻老虎音符表

unsigned char code TwoTigerNote[] = {

1, 2, 3, 1, 1, 2, 3, 1, 3, 4, 5, 3, 4, 5,

5,6, 5,4, 3, 1, 5,6, 5,4, 3, 1, 1, 5, 1, 1, 5, 1,

};

//兩隻老虎節拍表,4 表示一拍,1 就是 1/4 拍,8 就是 2 拍

unsigned char code TwoTigerBeat[] = {

4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 8, 4, 4, 8,

3,1, 3,1, 4, 4, 3,1, 3,1, 4, 4, 4, 4, 8, 4, 4, 8,

};

//用節拍索引作為循環變量

for (beat=0; beat

while (!tmrflag); //每次定時器中斷完成後,檢測並處理節拍

tmrflag = 0;

if (time == 0){ //當前節拍播完則啟動一個新節拍

note = TwoTigerNote[beat] - 1;

T0RH = NoteReload[note] >> 8;

T0RL = NoteReload[note];

//計算節拍總時間,右移 2 位相當於除 4,移位代替除法可以加快執行速度

beatTime = (TwoTigerBeat[beat] * NoteFrequ[note]) >> 2;

//計算發聲時間,為總時間的 0.75,移位原理同上

soundTime = beatTime - (beatTime >> 2);

enable = 1; //指示蜂鳴器開始發聲

time++;

}else{ //當前節拍未播完則處理當前節拍

//當前持續時間到達節拍總時間時歸零,

//並遞增節拍索引,以準備啟動新節拍

if (time >= beatTime){

time = 0;

beat++;

}else{ //當前持續時間未達到總時間時,

time++; //累加時間計數

//到達發聲時間後,指示關閉蜂鳴器,

//插入 0.25*總時間的靜音間隔,

if (time == soundTime){

enable = 0; //用以區分連續的兩個節拍

}

}

}

}

}

/* T0 中斷服務函數,用於控制蜂鳴器發聲 */

void InterruptTimer0() interrupt 1{

TH0 = T0RH; //重新加載重載值

TL0 = T0RL;

tmrflag = 1;

if (enable){ //使能時反轉蜂鳴器控制電平

BUZZ = ~BUZZ;

}else{ //未使能時關閉蜂鳴器

BUZZ = 1;

}

}

相關焦點

  • 單片機蜂鳴器控制程序和驅動電路圖
    壓電式為壓電陶瓷片發音,電流比較小一些,電磁式蜂鳴器為線圈通電震動發音,體積比較小。按照驅動方式分為有源蜂鳴器和無源蜂鳴器。這裡的有源和無源不是指電源,而是振蕩源。有源蜂鳴器內部帶了振蕩源,如圖 9-8 所示中,給了 BUZZ 引腳一個低電平,蜂鳴器就會直接響。而無源蜂鳴器內部是不帶振蕩源的,要讓他響必須給 500Hz~4.5KHz 之間的脈衝頻率信號來驅動它才會響。
  • 蜂鳴器驅動電路設計原理圖講解
    以下介紹的幾種蜂鳴器驅動電路是針對單片機I/O口的驅動電路,適用於現行的壓電式蜂鳴器。
  • 【基礎】單片機驅動蜂鳴器程序原理圖
    壓電式為壓電陶瓷片發音,電流比較小一些,電磁式蜂鳴器為線圈通電震動發音,體積比較小。按照驅動方式分為有源蜂鳴器和無源蜂鳴器。這裡的有源和無源不是指電源,而是振蕩源。有源蜂鳴器內部帶了振蕩源,如圖 9-8 所示中,給了 BUZZ 引腳一個低電平,蜂鳴器就會直接響。而無源蜂鳴器內部是不帶振蕩源的,要讓他響必須給 500Hz~4.5KHz 之間的脈衝頻率信號來驅動它才會響。
  • 單片機驅動蜂鳴器原理與設計
    蜂鳴器是一種一體化結構的電子訊響器,本文介紹如何用單片機驅動蜂鳴器,他廣泛應用於計算機、印表機、複印機、報警器、電話機等電子產品中作發聲器件。
  • 五款蜂鳴器驅動電路原理圖
    若採用圖1和圖3的方法進行驅動,蜂鳴器工作電壓只要不超過管子的極限參數即可隨時取用。像圖1,採用這種方法驅動蜂鳴器,再用編程控制器的I/O口進行控制,蜂鳴器都能響;但相對於圖3電路圖而言,採用圖1方式接,蜂鳴器沒有圖3響。
  • 電路找茬:蜂鳴器驅動低級錯誤電路分析
    單片機驅動蜂鳴器電路如下圖所示:乍一看沒有什麼問題,但是仔細一分析問題就來了,用上圖所示的電路驅動蜂鳴器可能存在驅動電流不夠,從而導致蜂鳴器不響的現象。分析如下:三極體是流控型器件,當單片機的管腳輸出5V高電平,三極體的導通壓降為0.7V時,三極體的基極電流計算如下:Ib=(5-0.7-Ui)/4.7k,由此公式可以發現,Ib的大小還取決於Ui,Ui是蜂鳴器的導通壓降,如果Ui較大則可能導致三極體不導通,從而導致驅動失敗。那這個電路該如何設計呢?
  • 蜂鳴器報警器電路圖匯總
    PORTC.3/T0作為I/O口通過三極體Q2來驅動蜂鳴器LS1,而PORTC.2/PWM0則作為PWM輸出口通過三極體Q1來驅動蜂鳴器LS2。另外在PORTA.3和PORTA.2分別接了兩個按鍵,一個是PWM按鍵,是用來控制PWM輸出口驅動蜂鳴器使用的;另一個是PORT按鍵,是用來控制I/O口驅動蜂鳴器使用的。連接按鍵的I/O口開內部上拉電阻。
  • 單片機pwm調光電路圖
    P2.0~P2.3分別連接DS12C887 晶片的片選端CS、地址選通輸入端AS、數據選擇端DS 與讀/寫輸入端R/W,P3.2 連接其鬧鐘中斷請求輸出端IRQ.P2.5~P2.7 分別連接液晶1602 的使能端EN、數據/命令選擇端RS、讀/寫選擇端RW.P2.4 作為蜂鳴器控制端。P3.0 作為DS18B20 的信號輸入端。
  • 如何有效編程單片機有源蜂鳴器驅動
    如果不能保證I/O的輸出性能可以根據情況增加上拉或者下拉電阻。切入正題:在程序裡面這個蜂鳴器的驅動就是個高低電平驅動。當然,如果單片機沒有很好的I/O跳變函數也可以這樣修改:這是因為傳入的參數是想讓蜂鳴器連續的發cnt聲。但是蜂鳴器除了發聲還有不發聲的時候。也就是說蜂鳴器每響一次都需要關閉一次,如果沒有關閉操作肯定就不會出現響幾聲而是連續的響一聲,這個也很容易推理。3)在while循環完之後需要加一個蜂鳴器關閉操作。這裡假如傳進的參數是2,目的是讓蜂鳴器響兩聲。根據程序的執行步驟:cnt2變成4。
  • 小小蜂鳴器,驅動電路大有學問
    素材來源:晶片電子之家Part1 摘要  蜂鳴器是電路設計中常用的器件,廣泛用於工業控制報警、機房監控、門禁控制、計算機 等電子產品作預警發聲器件,驅動電路也非常簡單,然而很多人在設計時往往隨意設計,導 致實際電路中蜂鳴器不發聲、輕微發聲和亂發聲的情況發生。
  • 單片機有源蜂鳴器驅動之效率編程
    _u=ukgdp5a7629&id=524088004171】蜂鳴器是很常見的設備,分為無源和有源兩種。根據項目需求選擇不同類型的蜂鳴器。最近的項目裡有用到有源蜂鳴器對有源蜂鳴器。還是老一套,把電路板畫完,接著編程。在項目中原理圖如下:
  • 如何設計無需PWM也能驅動無源蜂鳴器的低成本電路?
    圖1 無源蜂鳴器常規驅動電路 如圖1所示,此圖為無源蜂鳴器的常規驅動電路。圖5 無源蜂鳴器驅動電路 第二,為電路加入了一個控制端。在實際的電路中,不能讓蜂鳴器一直鳴叫,所以需要進行控制。控制電路,筆者想到了兩種,讀者也可以發揮自己的想像,改進電路。
  • 單片機紅外遙控電路設計原理圖
    圖2a 簡單驅動電路圖2b 射擊輸出驅動電路如圖2a和圖2b是LED的驅動電路,圖2a是最簡單電路, 選用元件時要注意三極體的開關速度要快,還要考慮到LED的正向電流和反向漏電流,一般流過LED的最大正向電流為100mA,電流越大
  • 【硬體設計】蜂鳴器常見錯誤電路分析
    蜂鳴器是電路設計中常用的器件,廣泛用於工業控制、機房監控、門禁控制、計算機等電子產品,作為預警發聲器件。然而很多人在設計時往往隨意設計,導致實際電路中蜂鳴器不發聲、輕微發聲和亂發聲的情況發生。下面我們介紹最常用的兩類蜂鳴器:有源蜂鳴器和無源蜂鳴器。從驅動方式分類,有源驅動和無源驅動,有源蜂鳴器又稱為直流蜂鳴器,其內部已經包含了一個多諧振蕩器,只要在兩端施加額定直流電壓即可發聲,具有驅動、控制簡單的特點,但價格略高。
  • 單片機交通燈控制程序和設計原理
    本書所附贈的電路就是以USB ISP串行模式來對AT89S51進行編程的,其電路如圖3.9所示。在接下來的內容裡,我們均稱書中所附電路板為實驗板。圖3.9 AT89S51 USB ISP編程器電路圖1、2、USB編程器電路本實驗板電路採用USB接口對AT89S51進程編程。
  • 硬體電路設計之「蜂鳴器」
    蜂鳴器在實際硬體電路中比較常見,一般的開發板或者帶報警功能的系統,或是一些自檢測試板卡中都能見到,本文就針對蜂鳴器的分類、驅動方式等進行介紹。
  • 蜂鳴器演奏音樂「你笑起來真好看」
    所以我們要想實現蜂鳴器演奏音樂的話,只能選用無源蜂鳴器。單片機驅動蜂鳴器發聲原理單片機上面使用的蜂鳴器一般都是無源電磁式的蜂鳴器。它由外殼、振動膜片、磁鐵、電磁線圈、及振蕩器等組成。單片機IO引腳輸出的電流較小,單片機輸出的TTL電平基本上驅動不了蜂鳴器,因此需要設計一個電流放大的電路,具體實現如下圖所示。有源蜂鳴器和無源蜂鳴器的驅動電路是一樣的,都是如上圖所示。
  • 基於單片機的水塔水位檢測控制系統仿真設計
    圖1 單片機水塔水位控制原理3 電路設計水塔水位控制系統主要由CPU(AT89C51)、水位檢測接口電路、報警接口電路、存儲器擴展接口電路、復位電路、時鐘振蕩等部分組成,如圖2所示。圖3為系統硬體電路。
  • 【教程】51單片機輕鬆入門與實踐教程
    本書通過30個模塊實例全面講解單片機開發中的各種技術,包括單片機接口的擴展、存儲器的擴展、輸入/輸出及顯示技術、實用電子製作、傳感控制技術、電氣傳動及控制技術、單片機通信技術、典型器件及應用技術、外圍電路設計、軟體編程等等內容。本套課程基於暢學51開發板講解。包含:51單片機簡介、寄存器設置及使用、硬體測試、各個應用模塊器件原理及使用、外圍電路設計、51單片機C語言編程。
  • 單片機入門經典!11個單片機程序設計經典項目!25個項目資料免費放送!
    閃爍控制是安全燈、高層建築、高空飛行器、警示燈等設備燈光閃爍控制的原理基礎,也是單片機項目學習過程中最簡單的項目。這裡我們做為一個項目設計,詳細敘述項目實現的基本過程。1.電路設計電路硬體是單片機項目實現的基礎,在項目設計過程中必須先設計項目的電路原理。