ngx-agora
Version:
Angular wrapper for Agora RTC client (https://www.agora.io/en/)
233 lines • 21.3 kB
JavaScript
/**
* @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"]}