基于单片机的自动音乐播放器的方案设计书17107Word格式文档下载.docx

上传人:b****6 文档编号:15906432 上传时间:2022-11-17 格式:DOCX 页数:18 大小:331.57KB
下载 相关 举报
基于单片机的自动音乐播放器的方案设计书17107Word格式文档下载.docx_第1页
第1页 / 共18页
基于单片机的自动音乐播放器的方案设计书17107Word格式文档下载.docx_第2页
第2页 / 共18页
基于单片机的自动音乐播放器的方案设计书17107Word格式文档下载.docx_第3页
第3页 / 共18页
基于单片机的自动音乐播放器的方案设计书17107Word格式文档下载.docx_第4页
第4页 / 共18页
基于单片机的自动音乐播放器的方案设计书17107Word格式文档下载.docx_第5页
第5页 / 共18页
点击查看更多>>
下载资源
资源描述

基于单片机的自动音乐播放器的方案设计书17107Word格式文档下载.docx

《基于单片机的自动音乐播放器的方案设计书17107Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《基于单片机的自动音乐播放器的方案设计书17107Word格式文档下载.docx(18页珍藏版)》请在冰豆网上搜索。

基于单片机的自动音乐播放器的方案设计书17107Word格式文档下载.docx

一般音响电路是以正弦波信号驱动喇叭,产生悦耳的音乐的;

在数字电路里,则是以脉冲信号驱动喇叭以产生声音。

同样的频率,脉冲信号或正弦信号产生的音效,对于人类的耳朵来说很难有所区别。

若用单片机产生声音,可利用程序产生频率,送到输入/输出端口,例如P1.0,再从该点连接到喇叭的驱动电路,即可驱动喇叭。

2.1.2音频转换原理

若要产生音频脉冲,只要算出某一音频的周期,再将此周期除以2,即为半周期的时间。

利用定时器计时半周期时间,每当计时终止后就将P1.0反相,然后重复计时再反相。

就可在P1.0引脚上得到此频率的脉冲。

利用单片机的内部定时器使其工作计数器模式(MODEL1)下,改变其计数值TH0及TL0以产生不同频率的方法产生不同音阶。

例如,频率为523HZ,其周期T=1/523=1912us,因此只要令计时器计时956us/1us=956,每计数956次时将I/O反相,就可得到中音DO(523HZ)。

计数脉冲值与频率的关系式是:

N=F1/2/F2(式3-2-1)

式3-2-1中,N是计数值;

F1是机器频率(晶体振荡器为12MHZ时,其频率为1MHZ);

F2为想要产生的声音频率。

其计数初值T的求法如下:

T=65536–N=65536-F1/2/F2(式3-2-2)

本次设计采用16位定时方式,晶体振荡器频率为6MHZ,根据式3-2-1和式3-2-2可以计算出各音乐频率的计数器初值,再将十进制的计数器初值转换为四位16进制,将其制表写入程序中,通过查表装入要求的初值即可。

音阶与频率的对应关系如表3-1所示。

表2-1

音符

DO

RE

ME

FA

SO

LA

SI

低音简谱码

1

2

3

4

5

6

7

频率/Hz

523

587

659

698

784

880

987

高音简谱码

1046

1174

1318

1396

1567

1760

1975

2.1.3节拍的产生

音阶的频率是固定的,而节拍有快有慢,拍子越短节奏越快,拍子越长节奏越慢。

控制发音的时间有两种方法:

调用延时子程序或采用定时器中断。

本次设计采用的是定时器终端方式。

首先在整首乐曲中找出最短的拍子,一般为1/4拍,拍子的时间约为0.125s。

然后以1/4拍为基准,然后设定每0.125s产生一次中断,其定时器值为125000,定时常数为08F3H。

若采用模式2,定时器值太小,不是很好用。

所以采用模式1,将定时器值设为62500,即0CDCH,则只需要执行2次定时器中断就可以产生1/4拍的时间长度。

同样,若要产生其它的拍子(如1/2拍,3/4拍……),只需要定时器中断N次,产生N*0.125s定时,使其满足各个节拍的时间长度即可。

设计的程序按如下方法编写:

(1)将音符代码装入8位字节高4位,节拍代码装入低4位,组成一个字节,以此类推。

将整段乐曲转换成一定长度的编码表。

具体编程方法如下:

1.首先,定义toneh[]和tonel[]两个数组,将各个音乐频率的定时器初值的16进制数的高8位装入toneh[],低8位装入tonel[]。

2.利用单片机的定时器中断,将toneh[]和tonel[]的数据分别装入TH0和TL0,并且,收到信号P1.0就反相。

voidtimer0(void)interrupt1using1

{

P1_0=!

P1_0;

TH0=toneh[rti];

TL0=tonel[rti];

}

3.利用定时器1控制音乐节拍的时间长度,将上文所述的定时器初值装入定时器1。

voidtimer1(void)interrupt3using2

TH1=0x0c;

TL1=0xdc;

m++;

(2)在程序执行时顺序查此表,取出音符代码,查频率表,置入T/C口,取出节拍代码,供定时器使用,启动后即可发出声音。

2.1.4音频转换流程图

设计的软件流程如图2-2所示。

程序开始运行时先对单片机进行初始化,其中包括定时器及其工作方式的选择、外部中断设定、定时器初值的设定。

利用单片机,通过软件的方式产生所需要的音乐频率,并将收到的信号与音频编码表进行对比。

若信号在编码表中,则将该频率的定时器初值写入定时器中,并读取频率的音阶,再从单片机的P1.0口输出,经过音频放大器驱动喇叭发出声音,利用驱动喇叭演示程序即可控制音乐的节拍。

若信号不在编码表中,则返到初始化。

2.2时间显示程序设计

2.2.1设计思路

对于时间程序的设计,主要依靠单片机内部定时器的计数功能实现。

时钟由秒针、分针和时针组成,在程序中分别由sdata,mdata,hdata表示各单位的数据。

首先对sdata,mdata,hdata分别设定一个初值,其中sdata设为0,表示秒针初始为0。

然后利用定时器对秒针计数,当计数值达到1秒的时间后产生定时器中断,sdata的数据就加1。

由于本次设计采用的晶振频率为6MHz,所以定时器取值为2500。

将hdata的数据装入第一和第二个数码管,将mdata的数据装入第三和第四个数码管。

当sdata的数据为59时,若此时再来一个定时器中断,则秒针重新归零,而分针就加1。

同样,分针和时针的进位也是同一道理。

当设定的闹钟时间一到,程序即转入音频程序,驱动喇叭放出音乐。

2.2.2时钟程序流程图

时钟程序流程图如图2-3所示。

(应有简单的文字叙述或解释)

3硬件电路的设计

3.1硬件流程模块

设计的硬件流程模块如图3-1所示。

首先,PC机通过串口及MAX232芯片将程序下载到单片机中,其中包括把一个个的单音写入单片机的ROM存储器中,程序运行时再将音乐数据按顺序读出,利用单片机的定时器中断控制音乐节拍的长度,这样就能形成一段乐曲。

在单片机P1.0口接入音频放大电路,将单片机输出的信号放大,再通过喇叭播放音乐。

单片机P2口接4位共阴LED数码管,并外接1K欧的排阻,利用单片机内部的定

时器中断控制时间程序,然后在数码管上显示出时间。

3.2模块电路的设计

3.2.189C58RD+型单片机介绍

89C58RD+是一种带32KB闪烁可编程/可擦除制度存储器(EPEROM-FlashProgrammableandErasableReadOnlyMemory)的低电压,高性能CMOS的8位微处理器。

该器件采用ATMEL高密度非易失存储器制造技术制造,与工业标准的MCS-51的指令集和输出管脚相兼容。

由于将多功能8位CPU和闪烁存储器组合在单个芯片中,因而ATMEL的89C58RD+是一种高效微控制器,为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。

并且,比起跟它同种类型的89C51,它具有更大的Flash存储器,可下载很大容量的程序代码,因此功能更加强大,应用范围更广泛。

89C58RD+有40个引脚,32个外部双向输入/输出(I/O)端口,9个中断源,内含2个外中断口,3个16位可编程定时计数器,可编程UART串行通信口,SPI串行口,89C58RD+可以按照常规方法进行编程,也可以在线编程。

其将通用的微处理器和Flash存储器结合在一起,特别是可反复擦写的Flash存储器可有效地降低开发成本。

89C58RD+有PDIP、TQFP及PLCC等三种封装形式,以适应不同应用系统的需求。

89C58RD+管脚如图3-2所示,其中

(1)时钟引脚

XTAL1:

接外部晶体的一个引脚。

在单片机内部,它是构成片内振荡器的反相放大器的输入端。

当采用外部振荡器时,该引脚接收振荡器的信号,即把此信号直接接到内部时钟发声器的输入端。

XTAL2:

接外部晶体的另一个引脚。

在单片机内部,它是构成内部振荡器的反相放大器的输出端。

当采用外部振荡器时,此引脚应悬浮不连接。

注意:

如果采用片内的振荡电路,要在单片机的引脚XTAL1和XTAL2之间连接一个石英晶体或陶瓷谐振器,并接两个电容到地。

(2)控制线或其他电源的复位引脚

RST:

复位输入端。

ALE/

当访问外部寄存器时,地址锁存允许的输出电平用于锁存地址的低位字节。

在Flash编程期间,此管脚用于输入编程脉冲。

在平时,ALE以不变的频率周期输出正脉冲信号,次频率为振荡器频率的1/6。

因此它可用作对外部输出的脉冲或用于定时目的。

然而要注意的是:

每当用作外部数据存储器时,将跳过一个ALE脉冲。

如果禁止ALE的输出可在SFR8EH地址上置0。

此时,ALE只有在执行外部执行状态ALE禁止,置位无效。

外部程序存储器的选通信号。

在有外部程序存储器取指令期间,每个机器周期两次

有效。

但在访问外部数据存储器时,这两次有效的

信号将不出现。

/Vpp:

保持低电平时,则在此期间访问外部程序存储器(0000H-FFFFH),不管是否有内部程序存储器。

注意要加密方式1时,

将内部锁定为RESET;

断保持高电平时,此间访问内部程序存储器。

在Flash编程期间,此管脚也用于施加12V编程电源(Vpp)。

(3)输入/输出引脚

P0口:

P0口为一个8位漏极开路双向I/O口,每脚可吸收8个TTL门电流。

当P1口的管脚第一次写“1”时,被定义为高阻输入。

P0口能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。

在Flash编程时,P0口作为原码输入口,当Flash进行校验时,P0口输出原码,此时,P0口外部必须被拉高。

P1口:

P1口为一个内部提供上拉电阻的8位双向I/O,P1口缓冲器能接收输出4个TTL门电流。

P1口管脚写入“1”后,被内部上拉为高,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。

在Flash编程和校验时,P1口为第八位地址接收。

P2口:

P2口为一个内部提供上拉电阻的8位双向I/O,P2口缓冲器可接收,输出4个TTL门电流,当P2口被写“1”时,其管脚被内部上拉电阻拉高。

且作为输入。

并因此作为输入时,P2口的管脚被外部拉底,将输出电流。

这是由于内部上拉的缘故。

P2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。

在给出地址“1”时,它利用内部上拉优势,当对外部8位地址数据校验时,P2口输出其特殊功能起存器的内容。

P2口在Flash编程和校验时,接收高8位地址信号和控制信号。

P3口:

P3口为一个内部提供上拉电阻的8位双向I/O,可接收输出4个TTL门电流。

当P3口写入“1”后,它们被内部上拉为高电平,并用作输入

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > PPT模板 > 动态背景

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1