UNPKG

ngx-agora

Version:

Angular wrapper for Agora RTC client (https://www.agora.io/en/)

233 lines 21.3 kB
/** * @fileoverview added by tsickle * Generated from: lib/data/models/stream-spec.model.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * A class defining the `spec` paramter in the * [createStream](https://docs.agora.io/en/Video/API%20Reference/web/globals.html#createstream) method. * * * \@remark * - Do not set `video` and `screen` as `true` at the same time. * - To enable screen-sharing on the Firefox browser, ensure that the `screen` property is * set to `true`, and the `mediaSource` property has been set to specify a certain sharing mode. * * # Create a Stream * * You have two options to create an audio/video stream: * * ## Set the audio, video, and screen properties * const stream = AgoraRTC.createStream({ * streamID: uid, * audio:true, * video:true, * screen:false * }); * * * ## Set the audioSource and videoSource properties * * Compared with the first option, the * [audioSource](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.streamspec.html#audiosource) * and [videoSource](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.streamspec.html#videosource) * properties can specify the audio and video tracks for the stream. Use this option if you need to process the audio * and video before creating the stream. * * Use the `mediaStream` method to get the audio and video tracks from `MediaStreamTrack`, and then set `audioSource` and `videoSource`: * * navigator.mediaDevices.getUserMedia( * {video: true, audio: true} * ).then(function(mediaStream){ * var videoSource = mediaStream.getVideoTracks()[0]; * var audioSource = mediaStream.getAudioTracks()[0]; * // After processing videoSource and audioSource * var localStream = AgoraRTC.createStream({ * video: true, * audio: true, * videoSource: videoSource, * audioSource: audioSource * }); * localStream.init(function(){ * client.publish(localStream, function(e){ * //... * }); * }); * }); * * \@remark * - `MediaStreamTrack` refers to the `MediaStreamTrack` object supported by the browser. * - Currently this option only supports the Chrome brower. * * @see [MediaStreamTrack API](https://developer.mozilla.org/en-US/docs/Web/API/MediaStreamTrack) for details. * * * ### Enable Screen-sharing on the Chrome Web Browser * * const stream = AgoraRTC.createStream({ * streamID: uid, * audio:false, * video:false, * screen:true, * extensionId:"minllpmhdgpndnkomcoccfekfegnlikg"}); * * ### Enable Screen-sharing on the Firefox Web Browser * * localStream = AgoraRTC.createStream({ * streamID: uid, * audio: false, * video: false, * screen: true, * mediaSource: "screen", * }); * * For a tutorial on screen-sharing on a website, * @see [Share the Screen](https://docs.agora.io/en/Video/screensharing_web?platform=Web). * @record */ export function StreamSpec() { } if (false) { /** * Whether this stream contains an audio track. * @type {?} */ StreamSpec.prototype.audio; /** * Whether to enable audio processing. * * \@param [AEC] Whether to enable acoustic echo cancellation. * The default value is `true` (enable). If you wish not to enable the acoustic echo cancellation, set AEC as `false`. * \@param [AGC] Whether to enable audio gain control. * The default value is true (enable). If you wish not to enable the audio gain control, set AGC as false. * \@param [ANS] Whether to enable automatic noise suppression. * The default value is true (enable). If you wish not to enable automatic noise suppression, set ANS as false. * * \@remark * - Safari does not support this setting. * - Noise suppression is always enabled on Firefox. Setting `ANS` as `false` does not take effect on Firefox. * @type {?|undefined} */ StreamSpec.prototype.audioProcessing; /** * Specifies the audio source of the stream. * @type {?|undefined} */ StreamSpec.prototype.audioSource; /** * The camera device ID retrieved from the [getDevices](https://docs.agora.io/en/Video/API%20Reference/web/globals.html#getdevices) * method. * * The retrieved ID is ASCII characters, and the string length is greater than 0 and less than 256 bytes. * * When the string length is 0, this property is ignored. * @type {?|undefined} */ StreamSpec.prototype.cameraId; /** * The extension ID of the Chrome screen-sharing extension. * * ASCII characters only, and the string length must be greater than 0 and less than 256 bytes. * Set this property if you use the Chrome screen-sharing extension. * @see [Chrome Extension for Screen Sharing](https://docs.agora.io/en/Video/chrome_screensharing_plugin?platform=Web) for details. * * \@remark * Chrome 72 and later versions support screen sharing without the extension. You can leave extensionId as empty. * If you set the `extensionId`, then you need to use the screen-sharing extension. * @type {?|undefined} */ StreamSpec.prototype.extensionId; /** * Sets using the front or rear camera. * * You can set this parameter to use the front or rear camera on mobile devices: * - `"user"`: The front camera * - `"environment"`: The rear camera * @type {?|undefined} */ StreamSpec.prototype.facingMode; /** * The screen-sharing mode on the Firefox browser. * * If you are using the Firefox browser, setting this property specifies the screen-sharing mode: * - `"screen"`: (default) share the current screen * - `"application"`: share all windows of an App * - `"window"`: share a specified window of an App * * \@remark * Firefox on Windows does not support the application mode. * * @see * [Screen Sharing on Firefox](https://docs.agora.io/en/Video/screensharing_web?platform=Web#a-name-ff-a-screen-sharing-on-firefox) * for details. * @type {?|undefined} */ StreamSpec.prototype.mediaSource; /** * The microphone device ID retrieved from the * [getDevices](https://docs.agora.io/en/Video/API%20Reference/web/globals.html#getdevices) method. * * The retrieved ID is ASCII characters, and the string length is greater than 0 and less than 256 bytes. * * When the string length is 0, this property is ignored. * @type {?|undefined} */ StreamSpec.prototype.microphoneId; /** * Marks whether to mirror the local video image of the publisher in the local preview. * * This setting does not take effect in screen-sharing streams. * - `true`: (Default) Mirror the local video. * - `false`: Do not mirror the local video. * * Agora recommends enabling this function when using the front camera, and disabling it when using the rear camera. * @type {?|undefined} */ StreamSpec.prototype.mirror; /** * Whether this stream contains a screen-sharing track. * * @see [Share the Screen](https://docs.agora.io/en/Video/screensharing_web?platform=Web) for details. * @type {?|undefined} */ StreamSpec.prototype.screen; /** * Marks whether to share the audio playback when sharing the screen. * * - `true`: Share the local audio playback when sharing the screen. * - `false`: (Default) Do not share the local audio playback when sharing the screen. * * To share the local audio playback when sharing the screen, ensure that you set screen as `true`. * We recommend also setting [audio](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.streamspec.html#audio) * as false. If both `screenAudio` and `audio` are set as `true`, the stream only contains the local audio playback. * * \@remark * - This function supports only Chrome 73 or later on Windows. * - For the audio sharing to take effect, the user must check **Share audio** in the pop-up window when sharing the screen. * * \@since 3.0.0 * @type {?|undefined} */ StreamSpec.prototype.screenAudio; /** * The stream ID. * * Please set the stream ID as the user ID, which can be retrieved from the callback of * [Client.join](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.client.html#join). * @type {?|undefined} */ StreamSpec.prototype.streamID; /** * Whether this stream contains a video track. * @type {?} */ StreamSpec.prototype.video; /** * Specifies the video source of the stream. * * \@remark * If you use a video source created by the Canvas API, re-draw on the canvas every one second * when the drawing is still to keep the video publishing. * @type {?|undefined} */ StreamSpec.prototype.videoSource; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stream-spec.model.js","sourceRoot":"ng://ngx-agora/","sources":["lib/data/models/stream-spec.model.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkFA,gCAoIC;;;;;;IAhIC,2BAAe;;;;;;;;;;;;;;;;IAef,qCAIE;;;;;IAIF,iCAA+B;;;;;;;;;;IAS/B,8BAAkB;;;;;;;;;;;;;IAYlB,iCAAqB;;;;;;;;;IAQrB,gCAAoC;;;;;;;;;;;;;;;;;IAgBpC,iCAAkD;;;;;;;;;;IASlD,kCAAsB;;;;;;;;;;;IAUtB,4BAAiB;;;;;;;IAMjB,4BAAiB;;;;;;;;;;;;;;;;;;IAiBjB,iCAAsB;;;;;;;;IAOtB,8BAA2B;;;;;IAE3B,2BAAe;;;;;;;;;IAQf,iCAA+B","sourcesContent":["import { MediaStreamTrack } from './media-stream-track.model';\n\n/**\n * A class defining the `spec` paramter in the\n * [createStream](https://docs.agora.io/en/Video/API%20Reference/web/globals.html#createstream) method.\n *\n *  * @remark\n * - Do not set `video` and `screen` as `true` at the same time.\n * - To enable screen-sharing on the Firefox browser, ensure that the `screen` property is\n * set to `true`, and the `mediaSource` property has been set to specify a certain sharing mode.\n *\n * # Create a Stream\n *\n * You have two options to create an audio/video stream:\n *\n *  ## Set the audio, video, and screen properties\n *  const stream = AgoraRTC.createStream({\n *   streamID: uid,\n *   audio:true,\n *   video:true,\n *   screen:false\n *  });\n *\n *\n * ## Set the audioSource and videoSource properties\n *\n * Compared with the first option, the\n * [audioSource](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.streamspec.html#audiosource)\n * and [videoSource](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.streamspec.html#videosource)\n * properties can specify the audio and video tracks for the stream. Use this option if you need to process the audio\n * and video before creating the stream.\n *\n * Use the `mediaStream` method to get the audio and video tracks from `MediaStreamTrack`, and then set `audioSource` and `videoSource`:\n *\n * navigator.mediaDevices.getUserMedia(\n *     {video: true, audio: true}\n * ).then(function(mediaStream){\n *     var videoSource = mediaStream.getVideoTracks()[0];\n *     var audioSource = mediaStream.getAudioTracks()[0];\n *     // After processing videoSource and audioSource\n *     var localStream = AgoraRTC.createStream({\n *         video: true,\n *         audio: true,\n *         videoSource: videoSource,\n *         audioSource: audioSource\n *     });\n *     localStream.init(function(){\n *         client.publish(localStream, function(e){\n *             //...\n *         });\n *     });\n * });\n *\n * @remark\n * - `MediaStreamTrack` refers to the `MediaStreamTrack` object supported by the browser.\n * - Currently this option only supports the Chrome brower.\n *\n * @see [MediaStreamTrack API](https://developer.mozilla.org/en-US/docs/Web/API/MediaStreamTrack) for details.\n *\n *\n * ### Enable Screen-sharing on the Chrome Web Browser\n *\n * const stream = AgoraRTC.createStream({\n *   streamID: uid,\n *   audio:false,\n *   video:false,\n *   screen:true,\n *   extensionId:\"minllpmhdgpndnkomcoccfekfegnlikg\"});\n *\n * ### Enable Screen-sharing on the Firefox Web Browser\n *\n * localStream = AgoraRTC.createStream({\n *      streamID: uid,\n *      audio: false,\n *      video: false,\n *      screen: true,\n *      mediaSource: \"screen\",\n *    });\n *\n * For a tutorial on screen-sharing on a website,\n * @see [Share the Screen](https://docs.agora.io/en/Video/screensharing_web?platform=Web).\n */\nexport interface StreamSpec {\n  /**\n   * Whether this stream contains an audio track.\n   */\n  audio: boolean;\n  /**\n   * Whether to enable audio processing.\n   *\n   * @param [AEC] Whether to enable acoustic echo cancellation.\n   * The default value is `true` (enable). If you wish not to enable the acoustic echo cancellation, set AEC as `false`.\n   * @param [AGC] Whether to enable audio gain control.\n   * The default value is true (enable). If you wish not to enable the audio gain control, set AGC as false.\n   * @param [ANS] Whether to enable automatic noise suppression.\n   * The default value is true (enable). If you wish not to enable automatic noise suppression, set ANS as false.\n   *\n   * @remark\n   * - Safari does not support this setting.\n   * - Noise suppression is always enabled on Firefox. Setting `ANS` as `false` does not take effect on Firefox.\n   */\n  audioProcessing?: {\n    AEC?: boolean;\n    AGC?: boolean;\n    ANS?: boolean;\n  };\n  /**\n   * Specifies the audio source of the stream.\n   */\n  audioSource?: MediaStreamTrack;\n  /**\n   * The camera device ID retrieved from the [getDevices](https://docs.agora.io/en/Video/API%20Reference/web/globals.html#getdevices)\n   * method.\n   *\n   * The retrieved ID is ASCII characters, and the string length is greater than 0 and less than 256 bytes.\n   *\n   * When the string length is 0, this property is ignored.\n   */\n  cameraId?: string;\n  /**\n   * The extension ID of the Chrome screen-sharing extension.\n   *\n   * ASCII characters only, and the string length must be greater than 0 and less than 256 bytes.\n   * Set this property if you use the Chrome screen-sharing extension.\n   * @see [Chrome Extension for Screen Sharing](https://docs.agora.io/en/Video/chrome_screensharing_plugin?platform=Web) for details.\n   *\n   * @remark\n   * Chrome 72 and later versions support screen sharing without the extension. You can leave extensionId as empty.\n   * If you set the `extensionId`, then you need to use the screen-sharing extension.\n   */\n  extensionId?: string;\n  /**\n   * Sets using the front or rear camera.\n   *\n   * You can set this parameter to use the front or rear camera on mobile devices:\n   * - `\"user\"`: The front camera\n   * - `\"environment\"`: The rear camera\n   */\n  facingMode?: 'user' | 'environment';\n  /**\n   * The screen-sharing mode on the Firefox browser.\n   *\n   * If you are using the Firefox browser, setting this property specifies the screen-sharing mode:\n   * - `\"screen\"`: (default) share the current screen\n   * - `\"application\"`: share all windows of an App\n   * - `\"window\"`: share a specified window of an App\n   *\n   * @remark\n   * Firefox on Windows does not support the application mode.\n   *\n   * @see\n   * [Screen Sharing on Firefox](https://docs.agora.io/en/Video/screensharing_web?platform=Web#a-name-ff-a-screen-sharing-on-firefox)\n   * for details.\n   */\n  mediaSource?: 'screen' | 'application' | 'window';\n  /**\n   * The microphone device ID retrieved from the\n   * [getDevices](https://docs.agora.io/en/Video/API%20Reference/web/globals.html#getdevices) method.\n   *\n   * The retrieved ID is ASCII characters, and the string length is greater than 0 and less than 256 bytes.\n   *\n   * When the string length is 0, this property is ignored.\n   */\n  microphoneId?: string;\n  /**\n   * Marks whether to mirror the local video image of the publisher in the local preview.\n   *\n   * This setting does not take effect in screen-sharing streams.\n   * - `true`: (Default) Mirror the local video.\n   * - `false`: Do not mirror the local video.\n   *\n   * Agora recommends enabling this function when using the front camera, and disabling it when using the rear camera.\n   */\n  mirror?: boolean;\n  /**\n   * Whether this stream contains a screen-sharing track.\n   *\n   * @see [Share the Screen](https://docs.agora.io/en/Video/screensharing_web?platform=Web) for details.\n   */\n  screen?: boolean;\n  /**\n   * Marks whether to share the audio playback when sharing the screen.\n   *\n   * - `true`: Share the local audio playback when sharing the screen.\n   * - `false`: (Default) Do not share the local audio playback when sharing the screen.\n   *\n   * To share the local audio playback when sharing the screen, ensure that you set screen as `true`.\n   * We recommend also setting [audio](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.streamspec.html#audio)\n   * as false. If both `screenAudio` and `audio` are set as `true`, the stream only contains the local audio playback.\n   *\n   * @remark\n   * - This function supports only Chrome 73 or later on Windows.\n   * - For the audio sharing to take effect, the user must check **Share audio** in the pop-up window when sharing the screen.\n   *\n   * @since 3.0.0\n   */\n  screenAudio?: boolean;\n  /**\n   * The stream ID.\n   *\n   * Please set the stream ID as the user ID, which can be retrieved from the callback of\n   * [Client.join](https://docs.agora.io/en/Video/API%20Reference/web/interfaces/agorartc.client.html#join).\n   */\n  streamID?: number | string;\n  /** Whether this stream contains a video track. */\n  video: boolean;\n  /**\n   * Specifies the video source of the stream.\n   *\n   * @remark\n   * If you use a video source created by the Canvas API, re-draw on the canvas every one second\n   * when the drawing is still to keep the video publishing.\n   */\n  videoSource?: MediaStreamTrack;\n}\n"]}