单片机控制蜂鸣器鸣奏音乐.doc_第1页
单片机控制蜂鸣器鸣奏音乐.doc_第2页
单片机控制蜂鸣器鸣奏音乐.doc_第3页
单片机控制蜂鸣器鸣奏音乐.doc_第4页
单片机控制蜂鸣器鸣奏音乐.doc_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

单片机控制蜂鸣器鸣奏音乐 中北大学:马政贵首先介绍蜂鸣器的发声原理。我们都知道,音调和音调的时长是音符的主要特征,通过产生不同的音调和音调的时长可以奏出不同的音符来。然后一个个音符串联在一起就可以产生美妙的音乐来了。音调主要由声音的频率决定,通过单片机给蜂鸣器不同的音频脉冲来产生不同的音调。要产生音频脉冲,只要算出某一音频的周期(周期=1/频率),然后将此周期除以2即为半周期的时间。利用单片机的定时器工作在计数模式MODE1下,设定TH0和TL0的值以产生这半个周期,每当计时到达时就将输出脉冲的I/O(即接蜂鸣器的那个管脚)反相,然后重复计时此半个周期再对I/O反相,就可以在I/O引脚上得到此频率的脉冲。如果没有必要进行精确的计时,可以用for循环空语句来粗略计时即可(本文选用此法)。当单片机使用11.0592Mhz的晶振时,for(i=0;i115;i+);这个空循环延时约为1ms;当晶振选用12Mhz时,可使用for(i=0;i125;i+);这个空循环来延时1ms。在这个空循环外头再进行一次循环就可以实现延时若干ms。如:/实现延时若干ms,晶振为11.0592Mhzvoid delay(unsigned int i) unsigned char j; while(i-) for(j=0;j115;j+) ; /例如delay(1000)编便可以实现延时1s/实现延时若干ms,晶振为12Mhzvoid delay(unsigned int i) unsigned char j; while(i-) for(j=0;j125;j+) ; /例如delay(1000)编便可以实现延时1s知道如何产生不同的频率的音调和进行音调的延时的之后,我们便可以编写程序来让单片机控制蜂鸣器来鸣奏音乐了。下面附上不同音调所对应的频率表: 下文介绍了让单片机控制蜂鸣器进行鸣奏音乐的两种方法。第一种方法是基础的方法,就是顺序地让蜂鸣器挨个地演奏每个音符。方法一:(此歌曲是莫斯哥郊外的晚上的乐曲)#include sbit fmq=P36;void delay(unsigned int a) unsigned char b; while(a-) for(b=0;b115;b+) ; void yanzou(unsigned char i,unsigned int pai) unsigned char y;unsigned int j; for(j=0;jpai;j+) fmq=0; for(y=0;yi;y+) ; fmq=1; for(y=0;yi;y+) ; void main()while(1) yanzou(65,220); /1/2拍 中音6yanzou(55,262); /1/2拍 高音1yanzou(44,330); /1/2拍 高音3yanzou(55,262); /1/2拍 高音1yanzou(49,587); /1拍 高音2yanzou(55,262); /1/2拍 高音1yanzou(58,247); /1/2拍 中音7 yanzou(44,660); /1拍 高音3yanzou(49,587); /1拍 高音2yanzou(65,880); /2拍 中音6yanzou(55,262); /1/2拍 高音1yanzou(44,330); /1/2拍 高音3yanzou(37,392); /1/2拍 高音5yanzou(37,392); /1/2拍 高音5 yanzou(65,440); /1拍 中音6yanzou(37,392); /1/2拍 高音5yanzou(41,349); /1/2拍 高音4yanzou(44,2640); /4拍 高音3yanzou(41,698); /1拍 高音4yanzou(37,784); /1拍 高音5yanzou(29,492); /1/2拍 高音7yanzou(33,440); /1/2拍 高音6yanzou(44,660); /1拍 高音3delay(250);yanzou(58,494); /1拍 中音7yanzou(65,220); /1/2拍 中音6yanzou(44,330); /1/2拍 高音3yanzou(49,293); /1/2拍 高音2yanzou(41,698); /1拍 高音4yanzou(41,698); /1拍 高音4yanzou(37,392); /1/2拍 高音5yanzou(41,349); /1/2拍 高音4yanzou(44,660); /1拍 高音3yanzou(49,293); /1/2拍 高音2yanzou(55,262); /1/2拍 高音1yanzou(44,660); /1拍 高音3yanzou(49,587); /1拍 高音2yanzou(65,880); /2拍 中音6yanzou(65,880); /2拍 中音6yanzou(41,698); /1拍 高音4yanzou(37,784); /1拍 高音5yanzou(29,492); /1/2拍 高音7yanzou(33,440); /1/2拍 高音6yanzou(44,660); /1拍 高音3delay(250);yanzou(58,494); /1拍 中音7yanzou(65,220); /1/2拍 中音6yanzou(44,330); /1/2拍 高音3yanzou(49,293); /1/2拍 高音2yanzou(41,698); /1拍 高音4yanzou(41,698); /1拍 高音4yanzou(37,392); /1/2拍 高音5yanzou(41,349); /1/2拍 高音4yanzou(44,660); /1拍 高音3yanzou(49,293); /1/2拍 高音2yanzou(55,262); /1/2拍 高音1yanzou(44,660); /1拍 高音3yanzou(49,587); /1拍 高音2yanzou(65,880); /2拍 中音6yanzou(65,880); /2拍 中音6 delay(5000);观察方法一的主函数可以发现,每个语句的形式和实现的功能都是一样的,于是可以想到用数组来进行代码的简化。方法二便是通过数组来实现的。方法二:(此乐曲是让我们荡起双桨)#include sbit fmq=P36;sbit start=P14; /定义了一个按键进行控制,当按键按下时,开始演奏音乐void delay(unsigned int i) unsigned char j;while(i-)for(j=0;j115;j+);void yanzou(unsigned char pinlv,unsigned int jiepai)unsigned char pl;unsigned int jp;if(jiepai=1) delay(250); /1/2拍暂停,即1/2拍的0else if(jiepai=2) delay(500); /1拍暂停,即1拍的0else for(jp=0;jpjiepai;jp+) fmq=0; for(pl=0;plpinlv;pl+); fmq=1; for(pl=0;plpinlv;pl+);void main()unsigned char i,x;unsigned char code pinlv=131,110,98, 87, 73, 87, 110,98, 131,0,110,98, 87, 73, 73, 65, 98, 87,87,87,73,65,73,65,55,58,65,73,65,87,110,98,87,73,110,131,110,98,87,65,73,73,0,87,65,65,73,82,87,98,87,73,131,110,98,0,110,98,87,73,65,55,58,65,73,87,65,65; unsigned int code jiepai=110,131,147,494,196,165,131,294,440,1,131,147,165,588,196,440,294,660,330,165,196,880,588,220,262,124,110,196,220,330,131,147,495,196,262,220,131,147,165,220,784,392,2,660,660,220,196,175,330,588,495,196,110,131,147,2,131,147,330,392,440,524,247,220,196,165,880,880;i=68; /数组共有68个元

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论