微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

React-Amazon Chime:当本地视频关闭时,远程用户的视频磁贴变黑

如何解决React-Amazon Chime:当本地视频关闭时,远程用户的视频磁贴变黑

我正在使用 Amazon-chime-sdk-js 通过 React JS 创建视频会议服务。我正在跟踪一个包含本地和远程视频图块的“tileStates”数组。 tileStates 数组在观察者的“videoTileDidUpdate”和“videoTileWasRemoved”方法中更新。 'tileStates' 数组中的图块使用 'bindVideoElement' 方法绑定到视频元素。当用户加入会议时,所有视频磁贴似乎都能正常工作。但是当用户关闭他的相机时,他屏幕上的远程用户的图块之一变黑。该错误的发生并不一致,即有人关闭相机并不能保证远程用户的其中一个视频在其屏幕上变黑。有时会出现,有时不会。

以下是观察者方法的本质:

videoTileDidUpdate: tileState => {
    setState((state)=> {
       const { tileStates } = state;
       const tileId = parseInt(tileState.tileId,10);
       const index = tileStatesDraft.findindex(tileState => tileState.tileId === tileId)}); 
       if (index >= 0) {
           return;
       }
       tileStatesDraft.push(tileState);
       return { tileStates: tileStatesDraft };
}

videoTileWasRemoved: tileId => {
   setState( state => {
      const { tileStates } = state;
      const tileStatesDraft = [...tileStates];
      let index = tileStatesDraft.findindex(tileState => tileState.tileId === tileId);

      if (index >= 0) {
          tileStatesDraft.splice(index,1);
         return { tileStates: tileStatesDraft };
      }
   })
}

视频流有界如下:

const videoElement = this.videoRef.current;
meeting.meetingSession.audioVideo.bindVideoElement(tile.tileId,videoElement); 

The black screen

以下是重新创建错误的顺序(请记住,错误并不总是重新创建;有时一切正常):

  1. 用户 A 加入会议并打开摄像头
  2. 用户 B 加入会议并打开摄像头...两个用户可以完美地看到对方
  3. 用户 A 关闭了他的相机。 A的局部瓦片被移除,用户A的屏幕中B的视频瓦片变黑

** P.S.- 一旦用户 B 的磁贴在用户 A 的屏幕上变黑,即使用户 B 关闭他的相机,磁贴也不会被移除。即,用户B的瓷砖在他一侧变黑后,用户A的最后不会为用户B的相机调用videoTileWasRemoved**

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?