2013-10-24 3 views
0

WebRTC를 사용하여 HTML 페이지에서 비디오 공유를 활성화했습니다. 로컬 호스트에서 HTML 페이지를 실행하고 두 개의 다른 모질라 인스턴스를 검사 할 때 정상적으로 작동합니다. 그러나 원격 PC로 액세스 할 때 비디오가 표시되지 않습니다. 사용중인 코드는 다음과 같습니다.원격 PC에 WebRTC 비디오가 표시되지 않습니다.

<!DOCTYPE html> 
<html> 
<head> 
<script src="https://www.webrtc-experiment.com/socket.io.js"> </script> 
<script src="https://www.webrtc-experiment.com/RTCPeerConnection-v1.5.js"> </script> 
<script src="https://www.webrtc-experiment.com/video-conferencing/conference.js"> </script> 
</head> 

<body> 
<P> Press this button to start a new conference: 
<button id="setup-new-room">Setup New Conference</button></p> 
<table style="width: 100%;" id="rooms-list"></table> 
<div id="videos-container"></div> 

<script> 
    var config = { 
     openSocket: function(config) { 
      var SIGNALING_SERVER = 'http://webrtc-signaling.jit.su:80/', 
      defaultChannel = location.hash.substr(1) || 'video-conferencing-hangout'; 

      var channel = config.channel || defaultChannel; 
      var sender = Math.round(Math.random() * 999999999) + 999999999; 

     io.connect(SIGNALING_SERVER).emit('new-channel', { 
      channel: channel, 
      sender: sender 
     }); 

     var socket = io.connect(SIGNALING_SERVER + channel); 
     socket.channel = channel; 
     socket.on('connect', function() { 
      if (config.callback) config.callback(socket); 
     }); 

     socket.send = function(message) { 
      socket.emit('message', { 
       sender: sender, 
       data: message 
      }); 
     }; 

     socket.on('message', config.onmessage); 
    }, 
    onRemoteStream: function(media) { 
     var video = media.video; 
     video.setAttribute('controls', true); 
     video.setAttribute('id', media.stream.id); 
     videosContainer.insertBefore(video, videosContainer.firstChild); 
     video.play(); 
    }, 
    onRemoteStreamEnded: function(stream) { 
     var video = document.getElementById(stream.id); 
     if (video) video.parentNode.removeChild(video); 
    }, 
    onRoomFound: function(room) { 
     var alreadyExist = document.querySelector('button[data-broadcaster="' + room.broadcaster + '"]'); 
     if (alreadyExist) return; 

     var tr = document.createElement('tr'); 
     tr.innerHTML = '<td><strong>' + room.roomName + '</strong> shared a conferencing room with you!</td>' + 
         '<td><button class="join">Join</button></td>'; 
     roomsList.insertBefore(tr, roomsList.firstChild); 

     var joinRoomButton = tr.querySelector('.join'); 
     joinRoomButton.setAttribute('data-broadcaster', room.broadcaster); 
     joinRoomButton.setAttribute('data-roomToken', room.broadcaster); 
     joinRoomButton.onclick = function() { 
      this.disabled = true; 

      var broadcaster = this.getAttribute('data-broadcaster'); 
      var roomToken = this.getAttribute('data-roomToken'); 
      captureUserMedia(function() { 
       conferenceUI.joinRoom({ 
        roomToken: roomToken, 
        joinUser: broadcaster 
       }); 
      }); 
     }; 
    } 
}; 

var conferenceUI = conference(config); 
var videosContainer = document.getElementById('videos-container') || document.body; 
var roomsList = document.getElementById('rooms-list'); 

document.getElementById('setup-new-room').onclick = function() { 
    this.disabled = true; 
    captureUserMedia(function() { 
     conferenceUI.createRoom({ 
      roomName: 'Anonymous' 
     }); 
    }); 
}; 

function captureUserMedia(callback) { 
    var video = document.createElement('video'); 
    video.setAttribute('autoplay', true); 
    video.setAttribute('controls', true); 
    videosContainer.insertBefore(video, videosContainer.firstChild); 

    getUserMedia({ 
     video: video, 
     onsuccess: function (stream) { 
      config.attachStream = stream; 
      video.setAttribute('muted', true); 
      callback(); 
     } 
    }); 
} 
</script> 

</body> 

</html> 

비디오 쇼를 만들기 위해 무엇을 변경해야합니까?

+0

날씨 정보를 확인하고 빙상 후보가 바뀌 었는지 확인하십시오. –

답변