您的位置:首页 > 房产 > 建筑 > 网站案例代码_手机网站建设价格低_百度公司官网入口_太原网站建设谁家好

网站案例代码_手机网站建设价格低_百度公司官网入口_太原网站建设谁家好

2024/10/30 9:01:22 来源:https://blog.csdn.net/Cary_cacb/article/details/143275778  浏览:    关键词:网站案例代码_手机网站建设价格低_百度公司官网入口_太原网站建设谁家好
网站案例代码_手机网站建设价格低_百度公司官网入口_太原网站建设谁家好

在使用AvPlayer进行设计之前,需要获取相应对象,后期围绕该对象展开操作

    const player = await media.createAVPlayer()

然后对播放器进行初始化设置:

player.on('stateChange', (state) => {switch (state) {case 'initialized':player.prepare()break;case 'prepared':player.play()break;case 'playing':player.play()break;case 'paused':player.pause()break;case 'completed':player.stop() // 播放结束(如果需要循环播放这里可以用if判断是否循环,进入不同状态)break;case 'stopped':player.reset() // stop 时 reset -> 释放音频资源break;default:break;}

这里可以使用一个函数将AvPlayer对象的获取和初始化工作封装起来,方便后期调用,给出示例如下:

 async getAVPlayerInstance() {// 如果已存在,直接返回if (this.avPlayer !== null) {return this.avPlayer}// 初始化播放器const player = await media.createAVPlayer()player.on('stateChange', (state) => {switch (state) {case 'initialized':player.prepare()break;case 'prepared':player.play()break;case 'playing':player.play()break;case 'paused':player.pause()break;case 'completed':player.stop() // 播放结束break;case 'stopped':player.reset() // stop 时 reset -> 释放音频资源break;default:break;}})this.avPlayer = playerreturn this.avPlayer}

进行完初始化设置之后就可以将音频对象的各个状态进行监听并且能够进行相应的操作与更改,这里不多做展示。

接下来展示音频读取函数的一个书写示例(这里只展示RawFile资源文件的读取方法,沙箱文件读取或通过网络连接获取的数据需另行获取)

// 加载 src/main/resources/rawfile 的文件async playByRawSrc(rawFdPath: string) {const player = await this.getAVPlayerInstance()// 先释放原来的资源await player.reset()// 获取文件信息const context = getContext()// 加载 src/main/resources/rawfile 文件夹中的文件const fileDescriptor = await context.resourceManager.getRawFd(rawFdPath)// 设置播放路径player.fdSrc = fileDescriptor// 播放player.play()}

接下来给出一个暂停音频播放的函数,将播放器状态更改到其他状态的函数书写同理:

// 停止播放async stop() {const player = await this.getAVPlayerInstance()this.loop = falseplayer.stop()}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com