这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » DIY与开源设计 » 电子DIY » SoundPlay.h如何修改才能移植到STC12C5616里面?

共1条 1/1 1 跳转至

SoundPlay.h如何修改才能移植到STC12C5616里面?

菜鸟
2015-05-27 09:21:18     打赏

       我用的晶振是13.2256MHz,移植进去STC12C5616后,音乐播放失真严重,我把晶振换成12M也不行,以前把它移植进去STC89C52RC里面没有问题,我估计是这几个函数设置不对,12系列单片机与89系列单片机不一样。。可不知道如何修改。。
以下是部分程序:

//**************************************************************************
void InitialSound(void)
{
beep = 0;
Sound_Temp_TH1 = (65535-(1/1200)*SYSTEM_OSC)/256; // 计算TL1应装入的初值 (10ms的初装值)
Sound_Temp_TL1 = (65535-(1/1200)*SYSTEM_OSC)%256; // 计算TH1应装入的初值 
TH1 = Sound_Temp_TH1;
TL1 = Sound_Temp_TL1;
TMOD |= 0x11;
ET0 = 1;
ET1 = 0;
TR0 = 0;
TR1 = 0;
EA = 1;
}

void BeepTimer0(void) interrupt 1 //音符发生中断
{
beep = !beep;
TH0 = Sound_Temp_TH0;
TL0 = Sound_Temp_TL0;
}
//**************************************************************************
void Play(unsigned char *Sound,unsigned char Signature,unsigned Octachord,unsigned int Speed)
{
unsigned int NewFreTab[12]; //新的频率表
unsigned char i,j;
unsigned int Point,LDiv,LDiv0,LDiv1,LDiv2,LDiv4,CurrentFre,Temp_T,SoundLength;
unsigned char Tone,Length,SL,SH,SM,SLen,XG,FD;
for(i=0;i<12;i++) // 根据调号及升降八度来生成新的频率表 
{
j = i + Signature;
if(j > 11)
{
j = j-12;
NewFreTab[i] = FreTab[j]*2;
}
else
NewFreTab[i] = FreTab[j];

if(Octachord == 1)
NewFreTab[i]>>=2;
else if(Octachord == 3)
NewFreTab[i]<<=2;
} 

SoundLength = 0;
while(Sound[SoundLength] != 0x00) //计算歌曲长度
{
SoundLength+=2;
}

Point = 0;
Tone = Sound[Point]; 
Length = Sound[Point+1]; // 读出第一个音符和它时时值

LDiv0 = 12000/Speed; // 算出1分音符的长度(几个10ms) 
LDiv4 = LDiv0/4; // 算出4分音符的长度 
LDiv4 = LDiv4-LDiv4*SOUND_SPACE; // 普通音最长间隔标准 
TR0 = 0;
TR1 = 1;
while(Point < SoundLength)
{
SL=Tone%10; //计算出音符 
SM=Tone/10%10; //计算出高低音 
SH=Tone/100; //计算出是否升半 
CurrentFre = NewFreTab[SignTab[SL-1]+SH]; //查出对应音符的频率 
if(SL!=0)
{
if (SM==1) CurrentFre >>= 2; //低音 
if (SM==3) CurrentFre <<= 2; //高音
Temp_T = 65536-(50000/CurrentFre)*10/(12000000/SYSTEM_OSC);//计算计数器初值
Sound_Temp_TH0 = Temp_T/256; 
Sound_Temp_TL0 = Temp_T%256; 
TH0 = Sound_Temp_TH0; 
TL0 = Sound_Temp_TL0 + 12; //加12是对中断延时的补偿 
}
SLen=LengthTab[Length%10]; //算出是几分音符
XG=Length/10%10; //算出音符类型(0普通1连音2顿音) 
FD=Length/100;
LDiv=LDiv0/SLen; //算出连音音符演奏的长度(多少个10ms)
if (FD==1) 
LDiv=LDiv+LDiv/2;
if(XG!=1) 
if(XG==0) //算出普通音符的演奏长度 
if (SLen<=4) 
LDiv1=LDiv-LDiv4;
else
LDiv1=LDiv*SOUND_SPACE;
else
LDiv1=LDiv/2; //算出顿音的演奏长度 
else
LDiv1=LDiv;
if(SL==0) LDiv1=0;
LDiv2=LDiv-LDiv1; //算出不发音的长度 
if (SL!=0)
{
TR0=1;
for(i=LDiv1;i>0;i--) //发规定长度的音 
{
while(TF1==0);
TH1 = Sound_Temp_TH1;
TL1 = Sound_Temp_TL1;
TF1=0;
}
}
if(LDiv2!=0)
{
TR0=0; beep=0;
for(i=LDiv2;i>0;i--) //音符间的间隔
{
while(TF1==0);
TH1 = Sound_Temp_TH1;
TL1 = Sound_Temp_TL1;
TF1=0;
}
}
Point+=2; 
Tone=Sound[Point];
Length=Sound[Point+1];
}
beep = 1;
}

下面是网上下载的仿真和程序:

播放音乐.zip




关键词: 51     播放音乐    

共1条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]