2022年05月13日

ビデオ通話のトラブルに対する実装のコツ

今や、一般的となってきたテレワーク。
テレワークの必須ツールとしてビデオ通話がありますが、仕事の場面以外にもビデオ通話の活用が広がってきています。

どのビデオ通話アプリも優秀ですが、やはり利用者によってはうまく利用できていないケースもあります。アプリ提供者も問い合わせの対応に追われる場面もよく見受けられます。

この記事では様々な利用者、環境に応じて発生する問題に対してどのような実装をすればよいかをつらつらと記載します。主にブラウザ版(WebRTC)のビデオ通話アプリについてです。

この記事に記載の実装は以下にまとめて公開してます。
こちら

SDKに付随するサンプルをカスタマイズしています。

お役立ち資料ダウンロード

オンライン体験におけるブイキューブの技術サポートのご案内

【図解】システム開発のお手伝い

ブイキューブのソリューションアーキテクトが、寄り添います!
各種ライブ配信システムのアーキテクチャについて わかりやすい構成図にてご紹介!

無料ダウンロード

利用環境チェック

実際のビデオ通話を始める前に利用できるかの確認は重要です。
擬似的にビデオ通話を行う事で問題点をユーザーに認識させる事ができます。

  • 利用環境チェックについては以下にサンプルが公開されています。
    こちら
    利用環境チェックについてはこのサンプルを用いて解説します。

ブラウザのチェック

ブラウザ版の場合、そもそもWebRTCに対応しているかどうかがポイントになります。
Agora.io SDKではブラウザチェックのAPIが用意されています。

App.vue
    handleCompatibilityCheck() {
          this.currentTestSuite = "0";
          let testSuite = this.testSuites["0"];
          setTimeout(() => {
            testSuite.notError = AgoraRtc.checkSystemRequirements();
            testSuite.notError
              ? (testSuite.extra = this.t("fully_supported"))
              : (testSuite.extra = this.t("some_functions_may_be_limited"));
            this.handleMicrophoneCheck();
          }, 3000);
        },
    

AgoraRTC.checkSystemRequirements()がチェックするAPIになります。
falseが返却された場合にアラート表示して、ビデオ通話画面へ遷移させない処理が有効かと思います。

マイク・カメラのチェック

次にマイク・カメラが利用できるかがポイントになります。

マイクのチェック

App.vue

        handleMicrophoneCheck() {
          this.currentTestSuite = "1";
          let testSuite = this.testSuites["1"];
          this.sendStream = AgoraRtc.createStream({
            streamID: this.sendId,
            video: false,
            audio: true,
            screen: false
          });
          this.sendStream.init(
            () => {
              this.sendStream.play("test-send");
              let totalVolume = 0;
              this.microphoneCheckTimer = setInterval(() => {
                this.inputVolume = Math.floor(
                  this.sendStream.getAudioLevel() * 100
                );
                totalVolume += this.inputVolume;
              }, 100);
              setTimeout(() => {
                clearInterval(this.microphoneCheckTimer);
                this.sendStream.close();
                if (totalVolume < 60) {
                  testSuite.notError = false;
                  testSuite.extra = this.t("can_barely_hear_you");
                } else {
                  testSuite.extra = this.t("microphone_works_well");
                }
                this.handleSpeakerCheck();
              }, 7000);
            },
            err => {
              // do next test
              testSuite.notError = false;
              testSuite.extra = err.msg;
              try {
                this.sendStream.close();
              } catch (error) {
                throw(error);
              } finally {
                this.handleSpeakerCheck();
              }
            }
          );
        },
    

AgoraRtc.createStream()で実際にストリームを作成し、getAudioLevel()で入力ボリュームをチェックしています。

カメラのチェック

App.vue
    checkProfile(profile) {
          return new Promise((resolve, reject) => {
            this.sendStream && this.sendStream.stop();
            this.sendStream = AgoraRtc.createStream({
              streamID: this.sendId,
              video: true,
              audio: true,
              screen: false
            });
            this.sendStream.setVideoProfile(profile.enum);
            this.sendStream.init(
              () => {
                this.sendStream.play("test-send");
                setTimeout(() => {
                  let videoElement = document.querySelector("#video" + this.sendId);
                  if (
                    videoElement.videoWidth === profile.width &&
                    videoElement.videoHeight === profile.height
                  ) {
                    profile.status = "resolve";
                    resolve();
                  } else {
                    profile.status = "reject";
                    reject("Resolution mismatched");
                  }
                }, 1000);
              },
              err => {
                reject(err);
              }
            );
          });
        },
    

カメラのチェックも実際にストリームを作成し、再生をさせて期待されたVideoElementが生成されたかを判定しています。

低帯域用の対応

混雑しているWi-Fi環境や、月末に帯域制限がかかっている4G回線等はビデオ通話に必要な帯域が不足します。
その場合は、「映像の画質を落とす」「音声のみにする」という方法があります。最低限のコミュニケーションを保つという考え方です。

index.html
      rtc.client.enableDualStream(function() {
            console.log("enable dual stream success.");
          }, function(err) {
            console.log("dual stream error."+err);
          });
          //中略
          var highOrLow = 0;
          $("#switchVideo").on("click", function (e) {
            console.log("switchVideo")
            e.preventDefault();
            if (highOrLow === 0) {
              highOrLow = 1
              console.log("Set to low");
            }else {
              highOrLow = 0
              console.log("Set to high");
            }
            rtc.client.setRemoteVideoStreamType(rtc.remoteStreams[0], highOrLow);
          });
    

こちらは手動で画質を切り替えるサンプルになります。
自動で切り替えるには以下のAPIを利用します。


    client.setStreamFallbackOption(remoteStream, fallbackType);
    

fallbackTypeによって以下の振る舞いになります。
0:自動切り替え無効化
1:低画質に切り替え
2:低画質でも厳しい場合に音声のみ受信に切り替え

又、低画質の設定はデフォルトで90P程度ですが、指定する事も可能です。

index.html
rtc.client.setLowStreamParameter({bitrate:65, framerate:15, height:120, width:160});
    

ネットワーク環境の可視化

ビデオ通話中にもネットワーク環境の良し悪しを明示的に可視化する事も重要です。

index.html
      rtc.client.on('network-quality', function(stats) {
            console.log('downlinkNetworkQuality', stats.downlinkNetworkQuality);
            console.log('uplinkNetworkQuality', stats.uplinkNetworkQuality);
    
            if(stats.downlinkNetworkQuality == 0){
              $("#networkQuality").html("NetworkQuality:-");
            }else if(stats.downlinkNetworkQuality == 1 || stats.downlinkNetworkQuality == 2){
              $("#networkQuality").html("NetworkQuality:Good");
            }else{
              $("#networkQuality").html("NetworkQuality:Bad");
            }
          });
    

client.on('network-quality',funciton(){})で6段階の評価が可能です。
このAPIはRTTやパケットロス、ジッター 等でネットワーク環境の品質をチェックしています。

事後の確認

ビデオ通話で問題が発生し、事後に問い合わせがくるパターンもあります。
その場合に求められるのは原因です。システム側では問題がなく、ユーザーの環境に起因している事を示す必要があります。

録画データでの確認

Agora.ioでは録画の仕組みも提供しています。クラウド型とオンプレミス型になります。
実装方法は以下に解説があります。
Cloud Recording SDK クイックスタートガイド
On-premise Recording SDK クイックスタートガイド
「映像が見えなかった」という問い合わせに対して録画データを確認し、録画データに映像が残っていなかった場合は送信側の問題、映像が残っていれば受信側の問題という具合に切り分けが可能です。

CallSearchの活用

Call SearchはAgora Analyticsの機能の1つで、通話時の品質をデータ化し、それを視覚的にわかりやすく表示した機能です。

例えば、予期せぬ切断や音声途切れなど、通話の品質が良くなかった場合の解析用として通話の履歴、品質を確認することができます。

  • サポートセンターのFAQにCall Searchの説明・活用ガイドをまとめております。
  •  
  • こちら

ガイドブックダウンロード

【すぐ読める!ガイドブック】ビデオ通話・ライブ配信SDK「Agora」

【大充実】通話・配信SDK「Agora」ガイドブック

通話・配信サービス開発や、配信技術のリプレイスを検討中の方、必見の内容です。
Agora SDKの特徴から活用例まで徹底解説!

無料ダウンロード
ブイキューブ

執筆者ブイキューブ

Agoraの日本総代理店として、配信/通話SDKの提供だけでなく、導入支援から行い幅広いコミュニケーションサービスに携わっている。

関連記事

先頭へ戻る