如何解决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);
以下是重新创建错误的顺序(请记住,错误并不总是重新创建;有时一切正常):
** P.S.- 一旦用户 B 的磁贴在用户 A 的屏幕上变黑,即使用户 B 关闭他的相机,磁贴也不会被移除。即,用户B的瓷砖在他一侧变黑后,用户A的最后不会为用户B的相机调用videoTileWasRemoved**
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。