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

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

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

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

WebRTC

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

Q&A

解決済

2回答

1033閲覧

skywayでの実装方法:ユーザを自動で部屋にjoinさせる

olee46

総合スコア32

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

WebRTC

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

0グッド

0クリップ

投稿2017/12/20 12:17

※JavaScriptおよびプログラミング全般初心者です

#システムで実現したいこと:
ユーザーが「入室」ボタンをクリック

room1への入室を試みる

room1の参加人数が5人未満であれば、room1へ入室

room1の参加人数が5人以上であれば、room2へ入室を試みる

これを、5人未満のroomが見つかるまで繰り返す

#困っていること:

  • peerIdの一覧は取得できるが、どのpeerがどのroomに接続しているかを調べる方法がわからない
  • peerIdとroomを関連付ける(例えば、idを「room1peer1」のようにする)としても、peerIdを付け直す方法がわからない

一つのプログラム内で、idを指定せずにpeerオブジェクトを生成→idを指定して別のpeerオブジェクトを生成 というのをやってみましたが、エラーが出ましたので、一度peerオブジェクトを生成した場合、新しくidを指定したpeerオブジェクトは生成できないものだと認識しています

#知りたいこと:

  1. どのpeerがどのroomに入室しているかを取得する方法
  2. 生成したpeerオブジェクトのidを付け直す方法
  3. データベースとしてpeerとroomを管理する方法

上記のいずれかの方法を知りたいです
3.については、JSがクライアントサイドで、データベースの管理はサーバサイドで実行であることから、難しいのでは?と考えています

#補足:
PHPとMySQLを用いて、サーバー側でデータベースとしてpeerとroomの一覧を管理する方法も試しましたが、PHPはサーバサイドでJSはクライアントサイドということで、うまく実装できませんでした
Node.jsについての少し調べましたが、やはりサーバサイドなのでうまくいかないのでは…と考えております

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

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

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

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

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

guest

回答2

0

どのpeerがどのroomに入室しているかを取得する方法

こちらに関しては、SkyWay側からは提供されていないので、自分で実装する必要があります。
簡単なのはデータベースを使う方法かと思われます。
サーバーを準備するのが難しいのであれば、Firebase Realtime Databaseなどが使いやすいかと思います。

生成したpeerオブジェクトのidを付け直す方法

こちらのスライドの21枚目に方法が書かれています。

const peer = new Peer("My ID",{ key:SKYWAY_API_KEY, debug:3, });

こんな感じですね。

データベースとしてpeerとroomを管理する方法

サーバー側のアプリケーションとクライアントサイドでデータをやり取りするのであれば、APIを作る必要があります。
HTTPリクエストをサーバーに投げると、サーバーからデータを返してくれる仕組みです。
APIを作るための言語は、PHPでも、Node.jsでもOKです。ほかの言語も使えます。

投稿2017/12/20 12:59

sublimer

総合スコア403

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

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

olee46

2017/12/23 00:11

ありがとうございます。いまのところはベストアンサーの方で解決したのですが、Firebaseも見てみたいと思います!
guest

0

ベストアンサー

[自分] 部屋に参加する

[ルーム既存メンバー] すでに参加しているメンバーにpeerJoinイベントが発生

[ルーム既存メンバー] peerJoinイベントで自分の参加している部屋のメンバーのカウントを+1

[ルーム既存メンバー] メンバーカウントが参加可能最大人数を超えた場合は、参加したユーザー([自分])に "abort" を送信

[自分] "abort" を受信したら、その部屋から退室し次の部屋へ。 → ループ

とすれば、クライアントのみでも可能ではないでしょうか?

ポイントは、メンバーカウントは自分が参加した以降のメンバーの数であること。これにより、1つのルームのメンバーが複数人いたとしても、それぞれ管理するメンバーカウントは古い人が最大で以降新しいメンバーになるにつれ少なくなりますので、”最大人数越え”と判定するのは1人だけで、"abort"が送信されるのも1回のみとなります。

サンプルを作ってみました。(サンプルではメンバーをカウントするのではなく、配列で管理しています。)
サンプル
MAX_MEMBERという定数が参加可能人数ですのでこれを増減して試してみてください。

投稿2017/12/21 02:32

編集2017/12/21 09:06
turbgraphics200

総合スコア4267

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

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

olee46

2017/12/23 00:11

サンプルコードまでいただき、ありがとうございました! 自分は配列ではなくcountで制御してみましたが、今のところうまくいっています
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問