Skip to content
This repository has been archived by the owner on Jan 9, 2024. It is now read-only.

Latest commit

 

History

History
149 lines (131 loc) · 4.58 KB

README.md

File metadata and controls

149 lines (131 loc) · 4.58 KB

RICOH Live Streaming Conference

株式会社リコーが提供するRICOH Live Streaming Serviceを利用するためのRICOH Live Streaming Conference (Web Application Component) です。

RICOH Live Streaming Serviceは、映像/音声などのメディアデータやテキストデータなどを 複数の拠点間で双方向かつリアルタイムにやりとりできるプラットフォームです。

サービスのご利用には、API利用規約への同意とアカウントの登録、ソフトウェア利用許諾書への同意が必要です。 詳細は下記Webサイトをご確認ください。

はじめに

RICOH Live Streaming Conference は RICOH Live Streaming Service を使った様々な機能をiframeコンポーネントとしてWebアプリケーションへ簡単に組み込むためのWebアプリケーション用コンポーネントです。

配布パッケージ構成

  • README.md: 本文書
  • CHANGELOG.md: LSConfおよびLSConfSDKの変更履歴
  • SoftwareLicenseAgreement.txt: ソフトウェア使用許諾契約書
  • doc/
    • APIReference.md: LSConfSDKのAPI仕様
  • src/
    • ls-conf-sdk.d.ts: TypeScriptで必要となる型定義ファイル
    • ls-conf-sdk.js: LSConfSDK本体
    • lang/: 言語設定(本ディレクトリを ls-conf-sdk.js と同じ場所に配置してください)
  • sample/
    • README.md: LSConfを利用したサンプルアプリの説明
    • CHANGELOG.md: サンプルアプリの変更履歴
    • frontend/: サンプルアプリのfrontend
    • backend/: サンプルアプリのfrontend

アプリケーションからの利用例

...
<script src="../src/ls-conf-sdk.js"></script>
...
<script>
let frame = null;
async function createAndJoin() {
  try {
    frame = window.LSConferenceIframe.create(
      document.getElementById('frame-container'),
      {
        thetaZoomMaxRange: 8,
        defaultLayout: 'gallery',
        toolbar: {
          isHidden: false,
          isHiddenCameraButton: false,
          isHiddenMicButton: false,
          isHiddenScreenShareButton: false,
          isHiddenDeviceSettingButton: false,
          isHiddenExitButton: false
        },
        isHiddenVideoMenuButton: false,
        isHiddenRecordingButton: false,
        isHiddenSharePoVButton: true,
        theme: {
          primary: '#303030',
          background: '#f7f7fa',
          surface: '#fff',
          onPrimary: '#fff'
        }
      }
    );
  } catch(error) {
    console.error('LSConferenceIframe.create failed: ', error.detail.type);
    return;
  }

  frame.addEventListener('error', (event) => {
    console.log(`Error occurred, ${event.message}`);
  });

  frame.onShareRequested(() => {
    let accessToken = null;
    try {
      accessToken = await createAccessToken();
    } catch(error) {
      console.error('createAccessToken failed: ', error.detail.type);
    }
    const screenShareParameters = {
      connectionId: 'screenShareConnectionId',
      accessToken: accessToken,
    };
    return screenShareParameters;
  });

  let accessToken = null;
  try {
    accessToken = await createAccessToken();
  } catch(error) {
    console.error('createAccessToken failed: ', error.detail.type);
    return;
  }

  try {
    await frame.join({
      clientId: 'hoge',
      acccessToken: accessToken,
      connectionId: 'connectionId',
      connectOptions: {
        username: 'huga'
        enableVideo: true,
        enableAudio: true,
      }
    });
  } catch(error) {
    console.error('Join failed: ', error.detail.type);
  }
  console.log('Join success');
}

async function leave() {
  if (frame == null) {
    console.error('leave failed: iframe is not created.');
    return
  }

  try {
    await frame.leave();
  } catch(error) {
    console.error('Leave failed: ', error.detail.type);
  }
  console.log('Leave success');
}
</script>
...
<div>
  <button id="join-meeting" onclick="createAndJoin()">
    join meeting
  </button>
  <button id="leave-meeting" onclick="leave()">
    leave meeting
  </button>
  <div id="frame-container">
  </div>
</div>
...

createAccessToken() はアプリ側で実装すべきメソッドのため、ここでは詳細は割愛する