单片机课程设计报告电子音调发生器

上传人:大米 文档编号:543706702 上传时间:2023-04-15 格式:DOC 页数:32 大小:135KB
返回 下载 相关 举报
单片机课程设计报告电子音调发生器_第1页
第1页 / 共32页
单片机课程设计报告电子音调发生器_第2页
第2页 / 共32页
单片机课程设计报告电子音调发生器_第3页
第3页 / 共32页
单片机课程设计报告电子音调发生器_第4页
第4页 / 共32页
单片机课程设计报告电子音调发生器_第5页
第5页 / 共32页
点击查看更多>>
资源描述

《单片机课程设计报告电子音调发生器》由会员分享,可在线阅读,更多相关《单片机课程设计报告电子音调发生器(32页珍藏版)》请在金锄头文库上搜索。

1、-单片机课程设计实验报告电子音调发生器: 日期: 2009年6月29日星期一目录一实验目的2二设计任务及要求2三工作原理及设计思路2四实现功能设计3五软件设计3六电路设计35七调试36八实验体会37一实验目的1 了解计算机发声原理。2 熟悉定时器和键盘扫描电路的工作原理及编程方法。二设计任务及要求利用实验平台上的开关k0-k7和蜂鸣器设计电子音调发生器,要求:1利用实验平台上开关k0-k7进展音调选择,即拨动不同的开关产生不同的音调,依次拨动K0K7,蜂鸣器发出1234567i八个音调。2编写2支歌曲,并可进展选择播放。三工作原理及设计思路音节由不同频率的方波产生,音节与频率的关系如表1所示。

2、要产生音频方波,只要算出*一音频的周期1/频率,然后将此周期除以2,即为半周期的时间。利用计时器计时此半周期时间,每当计时到后就将输出方波的I/0反相,然后重复计时此半周期时间再对I/O反相,就可在I/O脚得到此频率的方波。在ZKS-03实验仪上,产生方波的I/O脚选用P1.7,通过跳线选择器JP1将单片机的P1.7与蜂鸣器的驱动电路相连。这样P1.7输出不同频率的方波,蜂鸣器便会发出不同的声音。另外,音乐的节拍是由延时实现的,如果1拍为0.4秒,1/4拍是0.1秒。只要设定延时时间,就可求得节拍的时间。延时作为根本延时时间,节拍值只能是它的整数倍,每个音节相应的定时器初值*可按下法计算: 1

3、/2*(1/f)=(12/fose)*(216-*)即 *=216-(fose/24f)其中f:音调频率,当晶振fose=11.0592MHz时,音节“1相应的定时器初值为*,则可得*=63777D=F921H 其它的可同样求得。 表1音调频率Hz*(HE*)1262F9212294F9E13330FA8C4349FAD85392FB686440FBE97494FC5Bi523FC8F四实现功能设计实现两个主要功能:电子琴与音乐播放;一个辅助功能:在液晶上显示相关信息。1、电子琴:4*4的矩阵16个按键,按键0实现两个功能的切换,其余按键分别发出音调低音5、6、7,中音1、2、3、4、5、6、

4、7,高音1、2、3、4、5。发音的同时在液晶显示屏上显示出对应的音调。2、音乐播放:按键0实现两个功能的切换,按键1实现播放类型选择单曲循环播放、所有循环播放,其余按键分别对应一首歌。目前已经有9首歌。播放的同时,在液晶上显示出歌名。五软件设计根据要实现的功能,流程图如下:开场系统初始化判断按键判断按键电子琴液晶显示录音调整时钟功能选择音乐*include *include *define nop _nop_() *define uchar unsigned char *define uint unsigned int*define PAI_BASE 15*define MUSIC_NUM 9

5、*define SCAN_CYCLE 500*define BEEP P3_3/*液晶显示相关变量*/sbit LCD_RS = P27; sbit LCD_RW = P26;sbit LCD_EN = P25;static uchar th0_f; /在中断中装载的 T0 的值高 8 位static uchar tl0_f; /在中断中装载的 T0 的值低 8 位static timebuffer,Record_counter,Record_flag=0;static uchar key2,key=16,scounter=0,Record_time;static uchar s_musicC

6、ounter=0*00,s_tableCounter;bit Rplay_flag=0;bit K0_flag=0;bit Music_flag0;bit Music_flag=0;bit Freq_flag=0;bit disptime_flag=0;bit musicAutoFlag=0;/sbit BEEP = P3_3; /喇叭输出脚/延时子程序1void delay(int ms) int i; while(ms-) for(i = 0; i 250; i+) _nop_(); _nop_(); _nop_(); _nop_(); /*/* */*检查LCD忙状态 */*lcd_bu

7、sy为1时,忙,等待。lcd-busy为0时,闲,可写指令与数据。 */* */*/bit lcd_busy() bit result; LCD_RS = 0; LCD_RW = 1; LCD_EN = 1; _nop_(); _nop_(); _nop_(); _nop_(); result = (bit)(P0&0*80); LCD_EN = 0; return result; /*/* */*写指令数据到LCD */*RS=L,RW=L,E=高脉冲,D0-D7=指令码。 */* */*/void lcd_wcmd(uchar cmd) while(lcd_busy(); LCD_RS =

8、 0; LCD_RW = 0; LCD_EN = 0; _nop_(); _nop_(); P0 = cmd; _nop_(); _nop_(); _nop_(); _nop_(); LCD_EN = 1; _nop_(); _nop_(); _nop_(); _nop_(); LCD_EN = 0; /*/* */*写显示数据到LCD */*RS=H,RW=L,E=高脉冲,D0-D7=数据。 */* */*/void lcd_wdat(uchar dat) while(lcd_busy(); LCD_RS = 1; LCD_RW = 0; LCD_EN = 0; P0 = dat; _nop_(); _nop_(); _nop_(); _nop_(); LCD_EN = 1; _nop_(); _nop_(); _nop_(); _nop_(); LCD_EN = 0; /*

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 医学/心理学 > 基础医学

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号