0

我正在尝试使用 Skylink API 制作像谷歌视频群聊这样的视频应用程序。如果房间里只有一个对等点,则对等点将是全屏。如果房间里有更多的同伴,其余的同伴将列在右下角,就像 google hangout 一样。

当全屏对等体离开房间时,列表中的一个对等体将取代全屏对等体,其余对等体仍在列表中。

我的想法是当全屏同行离开时,我使用 javascript 将<video>全屏视频替换为列表中的一个视频。但是,当我这样做时,全屏视频卡住了。看起来我停止了流,或者我不能简单地在另一个视频标签中显示我对等的流。

以下是我的javascript代码,请看函数skylink.on('peerJoined', function(peerId, peerInfo, isSelf)removeFullscreenVideo(peerId)

const VIDEO_LIST_NAME = "video-list";

/*
 * Create a new Skylink object and subscribe events using the on() function.
 */
var skylink = new Skylink();

/*
 * Configures the Skylink console log level that would determine the type of 
 * console logs that would be printed in the Web console.
 */
skylink.setLogLevel(4);

/* flag to record if anyone is fullscreen */
var existFullscreen = false;
var idFullscreen = null;
var videoIDs = [];

/* peerJoined: informs you that a peer has joined the room and 
 * shares their peerID and peerInfo a with you.
 */
skylink.on('peerJoined', function(peerId, peerInfo, isSelf) {
  /* We already have a video element for our video and don't 
   * need to create a new one.
   */
   console.log("peerinfo:", peerInfo);
  if(isSelf) return; 

  if(!existFullscreen){
    // if no one is fullscreen, create fullscreen video.
    addFullscreenVideo(peerId);
  } else{
    // if it exists fullscreen, create smallscreen video.
    addSmallscreenVideo(peerId);
  }
});

/* incomingStream: This event is fired after peerJoined when SkylinkJS starts 
 * receiving the audio and video streams from that peer. 
 */
skylink.on('incomingStream', function(peerId, stream, isSelf) {
  if(isSelf) return;
  var vid = document.getElementById(peerId);
  attachMediaStream(vid, stream);
});

/* peerLeft: informs you that a peer has left the room. Ee look in the DOM
 * for the video element with the events peerId and remove it.
 */
skylink.on('peerLeft', function(peerId) {
  if(peerId === idFullscreen){
    removeFullscreenVideo(peerId);
  }else{
    removeVideosItem(peerId);
  }
});

/* mediaAccessSuccess: The user needs to authorize his browser to 
 * allow your website access to their camera, microphone or both.
 */
skylink.on('mediaAccessSuccess', function(stream) {
  var vid = document.getElementById('myvideo');
  attachMediaStream(vid, stream);
});

/* Helper functions */
/* get Room ID */
function getRoomId() {
  var roomId = document.cookie.match(/roomId=([a-z0-9-]{36})/);
  if(roomId) {
    return roomId[1];
  }
  else {
    roomId = skylink.generateUUID();
    var date = new Date();
    date.setTime(date.getTime() + (30*24*60*60*1000));
    document.cookie = 'roomId=' + roomId + '; expires=' + date.toGMTString() + '; path=/';
    return roomId;
  }
};

function createVideo(peerId){
  /* create video tag: <video></video> */
  var vid = document.createElement('video');
  /* set attributes of video tage */ 
  vid.autoplay = true;
  vid.muted = true; // Added to avoid feedback when testing locally
  vid.id = peerId;
  return vid;
}

/* new fullscreen video */
function addFullscreenVideo(peerId){
  var vid = createVideo(peerId);
  var vidDiv = document.getElementById('vidDiv');
  vidDiv.insertBefore(vid, vidDiv.firstChild);
  vid.classList.add('fullscreen');
  idFullscreen = peerId;
  existFullscreen = true;
  videoIDs.push(peerId);
}

/* new small screnn video */
function addSmallscreenVideo(peerId){
  var vid = createVideo(peerId);
  var ul = document.getElementById(VIDEO_LIST_NAME);
  var li = document.createElement('li');
  ul.appendChild(li);
  li.appendChild(vid);
  li.id = VIDEO_LIST_NAME + peerId;
  vid.classList.add('smallscreen');
  videoIDs.push(peerId);
}

/* remove fullscreen video */
function removeFullscreenVideo(peerId){
  var index = videoIDs.indexOf(peerId);
  var vid = document.getElementById(peerId);
  videoIDs.splice(index, 1);
  // if there is still other peers in room, pick first item
  // in videos to be fullscreen,
  if(videoIDs.length != 0){
    var firstVideoId = videoIDs[0];
    var firstVideo = document.getElementById(firstVideoId);
    firstVideo.classList.remove('smallscreen');
    firstVideo.classList.add('fullscreen');
    var parent = vid.parentNode;
    vid.parentNode.replaceChild(firstVideo, vid);
    idFullscreen = firstVideoId;
  }
  else{
    existFullscreen = false;
    vid.parentNode.removeChild(vid);
  }
}

/* remove item from video list */
function removeVideosItem(peerId){
  var index = videoIDs.indexOf(peerId);
  var vid = document.getElementById(VIDEO_LIST_NAME + peerId);
  vid.parentNode.removeChild(vid);
  videoIDs.splice(index, 1);
}

我怎样才能做到这一点?谢谢你。

4

1 回答 1

1

也许您可以尝试检查<video>元素标签是否正在播放?你可以通过设置 DOM 属性 autoplay="true" 让它一直播放。

于 2016-10-04T09:27:40.710 回答