uniapp简单版语音播放

javascript 复制代码
mounted() {
		this.ScanAudio('http://118.178.137.235:88/ipoker.mp3', 3); // 开始播放音频
	},


ScanAudio(url, count) {
    // 递归终止条件:当循环次数小于等于 0 时,停止递归
    if (count <= 0) return;

    // 创建内部音频上下文对象
    var music = uni.createInnerAudioContext();
    
    // 设置音频资源链接
    music.src = url;
    
    // 开始播放音频
    music.play();

    // 监听音频播放结束事件
    music.onEnded(() => {
        // 销毁音频上下文对象,以释放资源
        music.destroy();
        
        // 在音频播放结束后,延迟一定时间后重新调用 ScanAudio 函数进行循环播放
        setTimeout(() => {
            // 递减循环次数,继续下一次播放循环
            this.ScanAudio(url, count - 1);
        }, music.duration * 1000); // 延迟时间等于音频时长乘以 1000 毫秒
    });
}

说明

  1. 当调用 ScanAudio(url, count) 时,它首先检查循环次数 count 是否小于等于 0。如果是,表示递归终止条件已满足,停止递归。

  2. 如果循环次数不小于等于 0,函数会创建一个内部音频上下文对象 music,然后设置该音频的资源链接为提供的 url

  3. 调用 music.play() 开始播放音频。

  4. 监听 music.onEnded 事件,当音频播放结束时触发。在此事件处理程序中,会先销毁音频上下文对象以释放资源,然后根据音频的时长乘以 1000 毫秒(即延迟一段时间)重新调用 ScanAudio 函数,实现循环播放。循环次数减少 1,从而控制循环次数。

后端传给多个语音如何播放

javascript 复制代码
<template>
	<view class="content">1212</view>
</template>

<script>
export default {
	data() {
		return {};
	},
	mounted() {
		const audioUrls = ['http://118.178.137.235:88/ipoker.mp3', 'http://118.178.137.235:88/ipoker.mp3', 'http://118.178.137.235:88/ipoker.mp3'];
		// 开始按顺序播放音频
		this.playSequentialAudioWithFixedDelay(audioUrls, 0, 3);
	},
	methods: {
		playSequentialAudioWithFixedDelay(urls, currentIndex, delayInSeconds) {
			if (currentIndex >= urls.length) {
				return;
			}
			const music = uni.createInnerAudioContext();
			music.src = urls[currentIndex];
			music.play();
			music.onEnded(() => {
				music.destroy();
				setTimeout(() => {
					this.playSequentialAudioWithFixedDelay(urls, currentIndex + 1, delayInSeconds);
				}, delayInSeconds * 1000);
			});
		}
	}
};
</script>

<style>
/* 样式省略 */
</style>
相关推荐
阿凤2116 小时前
uniapp运行到app端怎么打开文件
android·前端·javascript·uni-app
00后程序员张17 小时前
完整教程:如何将iOS应用程序提交到App Store审核和上架
android·macos·ios·小程序·uni-app·cocoa·iphone
00后程序员张17 小时前
iOS应用性能优化全解析:卡顿、耗电、启动与瘦身
android·ios·性能优化·小程序·uni-app·iphone·webview
Front思21 小时前
解决 uniapp Dart Sass 2.0.0 弃用警告
前端·uni-app·sass
星空下的曙光1 天前
uniapp编译到微信小程序接口获取不到数据uni.request
微信小程序·小程序·uni-app
2501_916007472 天前
iOS逆向工程:详细解析ptrace反调试机制的破解方法与实战步骤
android·macos·ios·小程序·uni-app·cocoa·iphone
00后程序员张2 天前
前端可视化大屏制作全指南:需求分析、技术选型与性能优化
前端·ios·性能优化·小程序·uni-app·iphone·需求分析
编程迪2 天前
基于Java和uniapp开发的名片交换分享系统企业名片管理软件个人电子名片小程序源码
java·uni-app·电子名片·名片小程序·名片软件源码
2501_915921433 天前
苹果iOS应用开发上架与推广完整教程
android·ios·小程序·https·uni-app·iphone·webview
2501_915106323 天前
HTTP和HTTPS协议工作原理及安全性全面解析
android·ios·小程序·https·uni-app·iphone·webview