uni-app 中封装全局音频播放器

在开发移动应用时,音频播放功能是一个常见的需求。无论是背景音乐、音效还是语音消息,音频播放都需要一个稳定且易于管理的解决方案。在 uni-app 中,虽然原生提供了 uni.createInnerAudioContext 方法用于音频播放,但直接使用它可能会导致代码冗余和难以维护。且如果在存在同时播放的语音消息,无法控制上一条语音是暂停还是等待。 因此,封装一个全局音频播放器是一个更好的选择。

1. 创建全局音频播放器模块

我们可以通过创建一个全局的音频播放器模块来管理音频的播放、暂停、停止等功能。以下是实现步骤:

1.1 创建音频播放器模块

在项目中创建一个名为 audioPlayer.js 的文件,用于封装音频播放器逻辑:

javascript 复制代码
// audioPlayer.js
const audioContext = uni.createInnerAudioContext();

// 音频播放器状态
const state = {
  isPlaying: false,
  currentUrl: null,
};

// 播放音频
function play(url) {
  if (state.isPlaying && state.currentUrl === url) {
    // 如果已经在播放同一个音频,直接返回
    return;
  }

  state.currentUrl = url;
  state.isPlaying = true;

  audioContext.src = url;
  audioContext.play();

  // 监听音频播放结束
  audioContext.onEnded(() => {
    state.isPlaying = false;
  });

  // 监听音频错误
  audioContext.onError((error) => {
    console.error("音频播放错误:", error);
    state.isPlaying = false;
  });
}

// 暂停音频
function pause() {
  if (!state.isPlaying) {
    return;
  }

  audioContext.pause();
  state.isPlaying = false;
}

// 停止音频
function stop() {
  if (!state.isPlaying) {
    return;
  }

  audioContext.stop();
  state.isPlaying = false;
}

// 获取当前播放状态
function getStatus() {
  return {
    isPlaying: state.isPlaying,
    currentUrl: state.currentUrl,
  };
}

// 暴露方法
export default {
  play,
  pause,
  stop,
  getStatus,
};
1.2 在全局挂载音频播放器

为了方便在各个页面中使用音频播放器,我们可以在 main.js 中将其挂载到全局对象 Vue.prototype 上:

javascript 复制代码
// main.js
import Vue from "vue";
import App from "./App";
import audioPlayer from "./audioPlayer";

Vue.config.productionTip = false;

// 挂载全局音频播放器
Vue.prototype.$audioPlayer = audioPlayer;

App.mpType = "app";

const app = new Vue({
  ...App,
});

app.$mount();

2. 使用全局音频播放器

在任何页面或组件中,都可以通过 this.$audioPlayer 调用音频播放器的方法。

到此就可以完成音频的创建与调用。

3. 问题

那么问题来了,全局的audioPlay,该如何监听播放结束并且加入特定的业务处理呢?

只需要修改onEnded,添加回调函数就好啦。

javascript 复制代码
 // 音频播放器状态
const state = {
  isPlaying: false,
  currentUrl: null,
  onEndedCallback: null, // 添加回调函数属性
};


onEnded(callback) {
    state.isPlaying = false;

    // 添加回调函数逻辑 
    if (state.onEndedCallback) {
      state.onEndedCallback(); // 调用回调函数
    }
  },


//播放时 添加回调
  this.$audioPlayer.play(
        "https://example.com/audio.mp3",
        this.onAudioEnded // 传入回调函数
      );

 onAudioEnded() {
      console.log("音频播放结束!");
      // 在这里执行音频播放结束后的逻辑
      // 例如:自动播放下一首歌曲
    },

通过为音频播放器的 ended 事件添加回调函数,可以更灵活地处理音频播放结束后的逻辑。

相关推荐
AI服务老曹2 小时前
【架构深评】深度解析异构计算下的 AI 视频管理平台:从 GB28181 接入到 X86/ARM 容器化部署的全链路实战
人工智能·架构·音视频
YWamy3 小时前
视频会议如何重构智能硬件生态?适配难点与场景落地全解析
音视频
ai产品老杨3 小时前
【架构深析】打破硬件壁垒:支持 X86/ARM 异构计算与源码交付的 GB28181 视频 AI 平台设计实践
arm开发·架构·音视频
美狐美颜SDK开放平台4 小时前
直播App画面发灰、卡顿严重?美颜SDK接入与优化全解析
人工智能·音视频·美颜sdk·短视频美颜sdk
开开心心就好4 小时前
解决打印机共享难题的实用工具
人工智能·vscode·游戏·macos·音视频·语音识别·媒体
ai产品老杨5 小时前
深度解析:基于异构计算架构的 AI 视频中台(支持 GB28181、RTSP、Docker 部署与源码交付)
人工智能·架构·音视频
MY_TEUCK5 小时前
【AI开发】从0到1写一个uni-app Vue3 小程序开发的Skill:用法、流程与踩坑复盘
人工智能·uni-app
做萤石二次开发的哈哈6 小时前
萤石音视频 SDK 对比维度有哪些?
音视频
雪芽蓝域zzs6 小时前
uni-app x uts类转换
uni-app
Cho1yon6 小时前
【第14期:多屏播放dvr视频和其他三方视频黑屏分析思路闪屏
车载系统·音视频