質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
WebRTC

WebRTC(Web Real-Time Communication)とは、プラグイン無しでウェブブラウザ間の音声通話・ビデオチャットなどリアルタイムコミュニケーションができるオープンフレームワークです。W3CがAPIレベルで、IETFがプロトコルレベルでそれぞれ標準化が進められています。

Q&A

0回答

2453閲覧

Skyway: roomの最初の参加者だと、streamイベントが発火されない

olee46

総合スコア32

WebRTC

WebRTC(Web Real-Time Communication)とは、プラグイン無しでウェブブラウザ間の音声通話・ビデオチャットなどリアルタイムコミュニケーションができるオープンフレームワークです。W3CがAPIレベルで、IETFがプロトコルレベルでそれぞれ標準化が進められています。

0グッド

0クリップ

投稿2018/02/12 03:32

プログラムの流れ:
ページを開く
→受信モード(stream: null)でjoinRoom()する
→「入室」ボタンを押す
→送受信モードにして、自分の映像も送信する(room.replaceStream(stream)を実行)

困っていること:
roomの最初の参加者だと、roomのstreamイベントが発火されない
(2番目以降の参加者だと発火されます)

使用環境:

  • Windows 10
  • Google Chrome

再現方法:
1つ目のタブでページを開く
→2つ目のタブでページを開く
→2つ目のタブで「入室」ボタンを押す

これだと、1つ目のタブでstreamイベントが発火されません

コード:

javascript

1/*略*/ 2peer.on('open', function(id) { 3 peerId = id; 4 5 room = peer.joinRoom(roomName, {mode: 'sfu', stream: null}); 6 roomHandler(); 7}) 8 9/*略*/ 10function roomHandler() { 11 /**/ 12 room.on('open', function() { 13 alert('joined room'); 14 }) 15 16 room.on('stream', function(stream) { 17 /**/ 18 alert('stream'); 19 var streamId = stream.peerId; 20 var ref = firebase.database().ref('/' + roomName + '/' + streamId); 21 ref.on('value', function(snapshot) { 22 var rIndex = snapshot.child('row-index').val(); 23 var cIndex = snapshot.child('cell-index').val(); 24 createVideo(streamId, stream, rIndex, cIndex); 25 }); 26 }) 27 28 room.on('peerLeave', function(id) { 29 removeVideo(id); 30 }) 31} 32/*略*/ 33

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問