HarmonyOS鸿蒙Next中AVPlayer播放器报5400102错误码

HarmonyOS鸿蒙Next中AVPlayer播放器报5400102错误码 这是错误信息, 我在模拟器运行的。PlayerPageInvoke avPlayer failed, code is 5400102, message is Operate Not Permit: operation not be permitted

import display from '@ohos.display'
import media from '@ohos.multimedia.media';

@Entry
@Component
export struct VideoPlayerPage {
  private count: number = 0;
  private avPlayer;
  private surfaceId: string = ''
  xcomponentController: XComponentController = new XComponentController()
  @State playerHeight: number = 180
  playerWidthPx: number;
  playerHeightPx: number;
  playTestUrl: string = "http://playertest.longtailvideo.com/adaptive/bipbop/gear4/prog_index.m3u8";

  aboutToAppear() {
    this.playerWidthPx = display.getDefaultDisplaySync().width;
    this.playerHeightPx = this.playerWidthPx * 9 / 16
    this.playerHeight = px2vp(this.playerHeightPx);
  }

  // 以下demo为使用fs文件系统打开沙箱地址获取媒体文件地址并通过url属性进行播放示例
  async avPlayerUrlDemo() {
    // 创建avPlayer实例对象
    this.avPlayer = await media.createAVPlayer();
    // 创建状态机变化回调函数
    this.setAVPlayerCallback();
    // 通过UIAbilityContext获取沙箱地址filesDir,以下为Stage模型获方式,如需在FA模型上获取请参考《访问应用沙箱》获取地址
    // 打开相应的资源文件地址获取fd,并为url赋值触发initialized状态机上报
    this.avPlayer.url = this.playTestUrl;
  }

  // 注册avplayer回调函数
  setAVPlayerCallback() {
    // seek操作结果回调函数
    this.avPlayer.on('seekDone', (seekDoneTime) => {
      console.info('#VideoPlayerPage' + `AVPlayer seek succeeded, seek time is ${seekDoneTime}`);
    })
    // error回调监听函数,当avPlayer在操作过程中出现错误时调用reset接口触发重置流程
    this.avPlayer.on('error', (err) => {
      console.error('#VideoPlayerPage' + `Invoke avPlayer failed, code is ${err.code}, message is ${err.message}`);
      this.avPlayer.reset(); // 调用reset重置资源,触发idle状态
    })
    // 状态机变化回调函数
    this.avPlayer.on('stateChange', async (state, reason) => {
      switch (state) {
        case 'idle': // 成功调用reset接口后触发该状态机上报
          console.info('#VideoPlayerPage' + 'AVPlayer state idle called.');
          this.avPlayer.release(); // 调用release接口销毁实例对象
          break;
        case 'initialized': // avplayer 设置播放源后触发该状态上报
          console.info('AVPlayerstate initialized called.');
          this.avPlayer.surfaceId = this.surfaceId; // 设置显示画面,当播放的资源为纯音频时无需设置
          this.avPlayer.prepare().then(() => {
            console.info('#VideoPlayerPage' + 'AVPlayer prepare succeeded.');
          }, (err) => {
            console.error('#VideoPlayerPage' + `Invoke prepare failed, code is ${err.code}, message is ${err.message}`);
          });
          break;
        case 'prepared': // prepare调用成功后上报该状态机
          console.info('#VideoPlayerPage' + 'AVPlayer state prepared called.');
          this.avPlayer.play(); // 调用播放接口开始播放
          break;
        case 'playing': // play成功调用后触发该状态机上报
          console.info('#VideoPlayerPage' + 'AVPlayer state playing called.');
          if (this.count !== 0) {
            console.info('#VideoPlayerPage' + 'AVPlayer start to seek.');
            this.avPlayer.seek(this.avPlayer.duration); //seek到视频末尾
          } else {
            this.avPlayer.pause(); // 调用暂停接口暂停播放
          }
          this.count++;
          break;
        case 'paused': // pause成功调用后触发该状态机上报
          console.info('#VideoPlayerPage' + 'AVPlayer state paused called.');
          this.avPlayer.play(); // 再次播放接口开始播放
          break;
        case 'completed': // 播放结束后触发该状态机上报
          console.info('#VideoPlayerPage' + 'AVPlayer state completed called.');
          this.avPlayer.stop(); //调用播放结束接口
          break;
        case 'stopped': // stop接口成功调用后触发该状态机上报
          console.info('#VideoPlayerPage' + 'AVPlayer state stopped called.');
          this.avPlayer.reset(); // 调用reset接口初始化avplayer状态
          break;
        case 'released':
          console.info('#VideoPlayerPage' + 'AVPlayer state released called.');
          break;
        default:
          console.info('#VideoPlayerPage' + 'AVPlayer state unknown called.');
          break;
      }
    })
  }

  build() {
    Column() {
      RelativeContainer() {
        XComponent({
          id: 'xcomponent',
          type: 'surface',
          controller: this.xcomponentController
        })
          .onLoad(() => {
            this.xcomponentController.setXComponentSurfaceSize({
              // surfaceWidth: this.playerWidthPx,
              // surfaceHeight: this.playerHeight
              surfaceWidth:1920,surfaceHeight:1080
            });
            this.surfaceId = this.xcomponentController.getXComponentSurfaceId()
            this.avPlayerUrlDemo()
          })
          .alignRules({
            left: { anchor: '__container__', align: HorizontalAlign.Start },
            top: { anchor: '__container__', align: VerticalAlign.Top }
          })
          .width('100%')
          .height('100%')
          .id('video_player')
      }.width('100%')
      .height(this.playerHeight)
      .backgroundColor('#000000')
    }.width('100%')
    .height('100%')
  }
}

更多关于HarmonyOS鸿蒙Next中AVPlayer播放器报5400102错误码的实战教程也可以访问 https://www.itying.com/category-93-b0.html

8 回复

我试了下你的代码,那个播放地址有点问题,我换了一个m3u8地址就可以播放

更多关于HarmonyOS鸿蒙Next中AVPlayer播放器报5400102错误码的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


问题是解决,可能跟网络有关,这边连接公司的网络,公司对一些访问有限制。这边切换到手机流量就正常,

基本信息

简介

  • 简单描述

详细描述

  • 更详细的说明

关键点

  • 关键信息一
  • 关键信息二

注意事项

  • 注意事项一
  • 注意事项二

权限加了没有

加了网络权限。还需要加其他?

有大佬解答下吗

在HarmonyOS鸿蒙Next中,AVPlayer播放器报5400102错误码通常表示媒体资源加载失败。该错误码可能由以下原因引起:

  1. 网络问题:播放器无法从指定的URL加载媒体资源,可能是网络连接不稳定或URL无效。
  2. 资源格式不支持:播放器不支持所请求的媒体资源格式。
  3. 资源路径错误:提供的媒体资源路径不正确或资源不存在。
  4. 权限问题:应用可能缺少访问网络或本地资源的必要权限。

要解决此问题,可以检查网络连接、验证资源URL、确保资源格式受支持,并确认应用具有必要的权限。

在HarmonyOS鸿蒙Next中,AVPlayer播放器报5400102错误码通常表示媒体资源加载失败。可能的原因包括:

  1. 网络连接问题,导致无法获取媒体资源;

  2. 媒体资源URL无效或不可访问;

  3. 设备存储空间不足,无法缓存媒体数据。

建议检查网络连接、确认资源URL有效性,并确保设备有足够的存储空间。如果问题持续,建议查看官方文档或联系技术支持。

回到顶部