for(i=0i<100i++)
{
BEEP=~BEEP//取反
DelayMS(t)
}
BEEP=~BEEP作用就是让蜂鸣器进行响一次停一次的交替,交替的时间间隔是由DelayMS(t)实现的。其中参数t就是想要延时的时间。
循环前i为0,BEEP应该初始化为0(不响)。
第一次循环:
BEEP取反得1,此时蜂鸣器在响,延迟t毫秒(响t毫秒),i++,进入下一次循环
第二次循环:
BEEP取反得0,此时蜂鸣器不响,延迟t毫秒(不响t毫秒),i++,进入下一次循环
.........
循环结束后BEEP赋值为0,让蜂鸣器停止。
所以就实现了蜂鸣器每隔tms响一次,不过能听见50次
uchar code DSY_CODE[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90}//标准音符频率对应的延时表
uchar code HI_LIST[]={0,226,229,232,233,236,238,240,241,242,244,245,246,247,248}
uchar code LO_LIST[]={0,4,13,10,20,3,8,6,2,23,5,26,1,4,3}
//三段音乐的音符
uchar code Song[][50]=
{
{1,2,3,1,1,2,3,1,3,4,5,3,4,5,5,6,5,3,5,6,5,3,5,3,2,1,2,1,-1},
{3,3,3,4,5,5,5,5,6,5,3,5,3,2,1,5,6,53,3,2,1,1,-1},
{3,2,1,3,2,1,1,2,3,1,1,2,3,1,3,4,5,3,4,5,5,6,5,3,5,3,2,1,3,2,1,1,-1}
}
//三段音乐的节拍
uchar code Len[][50]=
{
{1,1,1,1,1,1,1,1,1,1,2,1,1,2,1,1,1,1,1,1,1,1,1,1,1,2,1,2,-1},
{1,1,1,1,1,1,2,1,1,1,1,1,1,1,2,1,1,1,1,1,1,2,2,-1},
{1,1,2,1,1,2,1,1,1,1,1,1,1,1,1,1,2,1,1,2,1,1,1,1,1,1,1,2,1,1,2,2,-1}
}
//外部中断0
void EX0_INT() interrupt 0
{
TR0=0//播放结束或者播放中途切换歌曲时停止播放
Song_Index=(Song_Index+1)%3//跳到下一首的开头
Tone_Index=0
P2=DSY_CODE[Song_Index] //数码管显示当前音乐段号
} void main()
{
P2=0xc0
SPK=0
TMOD=0x00 //T0 方式 0
IE=0x83
IT0=1
IP=0x02
while(1)
{
while(K1==1) //未按键等待
while(K1==0) //等待释放
TR0=1 //开始播放
Tone_Index=0 //从第0 个音符开始
//播放过程中按下 K1 可提前停止播放(K1=0)。
//若切换音乐段会触发外部中断,导致 TR0=0,播放也会停止
while(Song[Song_Index][Tone_Index]!=-1&&K1==1&&TR0==1)
{
DelayMS(300*Len[Song_Index][Tone_Index])//播放延时(节拍)
Tone_Index++ //当前音乐段的下一音符索引
}
TR0=0 //停止播放
while(K1==0)//若提前停止播放,按键未释放时等待
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)