uniapp实现微信小程序音频播放功能

最近需要有个项目需要用到音频播放,第一个想到的是audio标签,但是查阅了uniapp官方文档,发现audio组件已经不维护了。
官网推荐使用uni.createInnerAudioContext api来实现音频播放。这篇文章最终实现了音频播放倒计时的功能,完整代码在文章最后。 一起来共同学习吧~

  • 实现音频播放功能,通过点击播放按钮实现音频播放,关键代码如下:
<button @click="audioPlay">点击播放音频</button>
data() {
	return {
		audioForm:{
		//音频播放路径
		src:'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-hello-uniapp/2cc220e0-c27a-11ea-9dfb-6da8e309e0d8.mp3',
		}
	}
},
methods:{
	audioPlay(){
		const innerAudioContext = uni.createInnerAudioContext();
		innerAudioContext.autoplay = true;
		innerAudioContext.src = this.audioForm.src;
		innerAudioContext.onError((res) => {
			//如果音频没有正常播放
			console.log(res.errCode);
		})
	}
}

如果点击按钮音频没有正常播放,查看控制台res.errCode的值

uniapp ios关闭后天声音播放失败 uniapp语音提示_前端

如果res.errCode=10004时,请查看你的音频格式,有些音频格式是只支持安卓或ios的,安卓和ios都支持的格式有m4a、wav、mp3、aac。具体参考一下uniapp官网文档. 如果想进入页面时自动播放,把**audioPlay()**在onLoad()生命周期中调用就好了。

  • 实现音频播放时,时间倒计时功能。类似于微信语音条。
    实现思路如下:
    在audioForm中添加两个变量,duration和times,分别用来记录倒计时音频总长度
    audioPlay()中点击播放视频时保存音频总时间,以及在播放过程中,给倒计时重新赋值,并且用音频总时间-当前播放第几秒,完成倒计时的功能。
//音频开始播放时会调用以下函数,
innerAudioContext.onCanplay(() => {
	innerAudioContext.duration;
	setTimeout(() => {
		//保存总时长,这里需要用到定时器,让函数延迟执行,不然获取不到值
		//innerAudioContext对象中的duration和buffered代表音频总时长
		this.audioForm.times = innerAudioContext.duration.toFixed(0)
	}, 10)
})
//音频播放的过程中会调用以下函数
innerAudioContext.onTimeUpdate(() => {
	//innerAudioContext对象中的currentTime代表当前音频播放到第几秒了。
	//用总时长减去当前播放的到第几秒了,然后赋值给倒计时,就实现了倒计时的功能。
	this.audioForm.duration = this.audioForm.times - innerAudioContext.currentTime.toFixed(0)
})
  • 完整代码如下:
<view>
		<button @click="audioPlay">点击播放</button>
		<text v-if="audioForm.duration">音频播放倒计时:{{audioForm.duration}}</text>
	</view>
data() {
			return {
				audioForm: {
					//音频路径
					src: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-hello-uniapp/2cc220e0-c27a-11ea-9dfb-6da8e309e0d8.mp3',
					//倒计时
					duration: '',
					//音频长度
					times: ''
				},
			}
		},
		methods: {
			//点击按钮实现音频播放倒计时的效果
			audioPlay() {
				const innerAudioContext = uni.createInnerAudioContext();
				innerAudioContext.autoplay = true;
				innerAudioContext.src = this.audioForm.src;
				innerAudioContext.onPlay(() => {
					console.log('开始播放');
				});
				//音频刚开始播放时会调用以下函数
				innerAudioContext.onCanplay(() => {
					console.log(innerAudioContext)
					innerAudioContext.duration;
					setTimeout(() => {
						//保存总时长,这里需要用到定时器,让函数延迟执行,不然获取不到值
						//innerAudioContext对象中的duration和buffered代表音频总时长
						this.audioForm.times = innerAudioContext.duration.toFixed(0)
					}, 10)
				})
				//音频播放的过程中会调用以下函数
				innerAudioContext.onTimeUpdate(() => {
					//innerAudioContext对象中的currentTime代表当前音频播放到第几秒了。
					//用总时长减去当前播放的到第几秒了,然后赋值给倒计时,就实现了倒计时的功能。
					this.audioForm.duration = this.audioForm.times - innerAudioContext.currentTime.toFixed(0)
				})
				//音频播放异常时调用以下函数
				innerAudioContext.onError((res) => {
					console.log(res.errCode);
				})
			}
		}

以上就是通过uniapp中的uni.createInnerAudioContext api来实现音频播放时倒计时的功能实现过程以及思路啦,更多详细信息请移步链接: uniapp官方文档音频组件控制。