此为英语单词朗读业务 适用于MP3格式
这里用到了AVpalyer系统api
AVPlayer是什么?
AVPlayer是鸿蒙@kit.MediaKit下面的一个可以实现播放音频资源(mp3等)接口
AVPlayer作用是什么?
使用AVPlayer可以播放对音频播放进行全流程控制:
创建AVPlayer ->设置播放资源 ->设置播放参数(循环播放)-> 播放控制(播放/暂停/跳转/停止)-> 重置 ->销毁资源
AVPlayer播放状态变化示意图
上图不容易看懂看这个图
AVpalyer支持在线MP3也支持本地MP3文件
这里使用的是在线MP3
这里我用的是某道的在线翻译
aboutToAppear() {
this.playMp3('http://dict.youdao.com/dictvoice?audio=hello&type=1')
}
//全局变量储存avPlay对象实例 Object() 表示空值 Object对象
avplayer: media.AVPlayer = Object()
aboutToDisappear(): void {
// 4.停止播放
this.avplayer.stop()
}
async playMp3(url: string) {
// 1.创建AVplayer对象实例
const avPlay = await media.createAVPlayer()
this.avplayer = avPlay
// 2.监听avPlay的状态变化
avPlay.on('stateChange', (state) => {
if (state === 'initialized') {
//表示avPlay已经设置了播放源
avPlay.prepare()
}
if (state === 'prepared') {
//设置player循环播放音频
avPlay.loop
// 表示avplayer已经进入了准备播放状态,此时就可以通知播放了
avPlay.play()
}
})
// 3.设置播放源 //url为外部传入的某道在线播放MP3地址
// 设置了播放源就会触发on里面的回调函数
avPlay.url = url
}