nertc-electron-sdk
Version:
nertc-electron-sdk
1,774 lines (1,701 loc) • 295 kB
text/typescript
import {
SoftwareRenderer,
GlRenderer,
IRenderer,
CustomRenderer
} from '../renderer';
import {
NERtcEngineAPI,
NERtcEngineContext,
NERtcChannelProfileType,
NERtcRemoteVideoStreamType,
NERtcVideoCanvas,
NERtcErrorCode,
NERtcSessionLeaveReason,
NERtcVideoProfileType,
NERtcAudioProfileType,
NERtcAudioScenarioType,
NERtcVideoConfig,
NERtcAudioFrameRequestFormat,
NERtcCreateAudioMixingOption,
NERtcCreateAudioEffectOption,
NERtcRectangle,
NERtcScreenCaptureParameters,
NERtcDevice,
NERtcStats,
NERtcAudioSendStats,
NERtcAudioRecvStats,
NERtcVideoSendStats,
NERtcVideoRecvStats,
NERtcNetworkQualityInfo,
NERtcClientRole,
NERtcConnectionStateType,
NERtcReasonConnectionChangedType,
NERtcAudioDeviceType,
NERtcAudioDeviceState,
NERtcAudioMixingState,
NERtcAudioMixingErrorCode,
NERtcAudioVolumeInfo,
NERtcLiveStreamStateCode,
NERtcLiveStreamTaskInfo,
NERtcVideoMirrorMode,
NERtcVideoScalingMode,
NERtcVoiceChangerType,
NERtcVoiceBeautifierType,
NERtcVoiceEqualizationBand,
NERtcStreamChannelType,
NERtcPullExternalAudioFrameCb,
NERtcChannelMediaRelayConfiguration,
NERtcVideoStreamType,
NERtcMediaPriorityType,
NERtcScreenCaptureWindowParam,
NERtcAudioRecordingQuality,
NERtcEncryptionConfig,
NERtcJoinChannelOptions,
NERtcJoinChannelOptionsEx,
NERtcCameraCaptureConfig,
NERtcVideoOutputOrientationMode,
NERtcDistanceRolloffModel,
NERtcSpatializerPositionInfo,
NERtcSpatializerRoomProperty,
NERtcSpatializerRenderMode,
NERtcAudioRecordingConfiguration,
VirtualBackgroundSource,
NERtcReverbParam,
NERtcSize,
CaptureSoureInfo,
NERtcFeatureType,
NERtcScreenCaptureSourceData
} from './defs'
import { EventEmitter } from 'events'
import process from 'process';
// const nertc = require('bindings')('nertc-electron-sdk');
const nertc = require('../../build/Release/nertc-electron-sdk.node');
const NERtcChannel = require('./channel').default;
/**
* @class NERtcEngine
*/
class NERtcEngine extends EventEmitter {
nertcEngine: NERtcEngineAPI;
renderers: Map<string, IRenderer>;
substreamRenderers: Map<string, IRenderer>;
renderMode: 1 | 2 | 3;
customRenderer: any;
/**
* NERtcEngine 类构造函数
* @returns {NERtcEngine}
*/
constructor() {
super();
this.nertcEngine = new nertc.NertcNodeEngine();
this.initEventHandler();
this.renderers = new Map();
this.substreamRenderers = new Map();
this.renderMode = this._checkWebGL() ? 1 : 2;
this.customRenderer = CustomRenderer;
}
/**
* 创建一个 NERtcChannel 对象
* @since V5.4.0
* <pre>
* 设置相同房间名称的用户会进入同一个通话房间。
* </pre>
* @param {string} name 房间名 字符串格式,长度为 1~ 64 字节。支持以下 89 个字符:a-z, A-Z, 0-9, space, !#$%&()+-:;≤.,>? @[]^_{|}~”
* @returns {object} NERtcChannel 对象
*/
createChannel(channelName: string): any {
let nertcChannel = new nertc.NertcNodeChannel(channelName);
return new NERtcChannel(channelName, nertcChannel);
}
/**
* 初始化 NERTC SDK 服务。
* <pre>
* 该方法用来进行初始化 NERTC 服务。传入云信为开发者签发的厂商秘钥进行初始化。在使用其他方法前,必须先调用该方法进行初始化。
* 初始化成功后,默认处于音视频通话模式。
* <b>NOTE:</b>
* - 必须使用同一个 App Key 才能进行通话。
* - 一个 NERtcEngine 实例对象只能使用一个 App Key。如需更换 App Key,必须先调用 {@link NERtcEngine#release} 方法释放当前实例资源再调用本方法初始化实例。
* </pre>
* @param {Object} context 传入的 RTC engine context 对象:NERtcEngineContext。
* @param {String} context.app_key 用户注册云信的 APP Key。如果您的开发包里面缺少 APP Key,请申请注册一个新的 APP Key。
* @param {String} context.log_dir_path 日志目录的完整路径,采用 UTF-8 编码。
* @param {number} [context.log_level=3] 日志级别,默认级别为 kNERtcLogLevelInfo。
* <pre>
* - 0 Fatal 级别日志信息。
* - 1 Error 级别日志信息。
* - 2 Warning 级别日志信息。
* - 3 Info 级别日志信息。默认级别。
* - 4 DetailInfo 级别日志信息。
* - 5 Verbos 级别日志信息。
* - 6 Debug 级别日志信息。如果您想获取最完整的日志,可以将日志级别设为该等级。
* - 7 不输出日志信息。
* </pre>
* @param {number} [context.log_file_max_size_KBytes=20480] 指定 SDK 输出日志文件的大小上限,单位为 KB。如果设置为 0,则默认为 20 M。
* @param {Object} context.server_config 私有化服务器地址,默认需要置空, 如需启用私有化功能,请 [提交工单](https://app.yunxin.163.com/global/service/ticket/create) 联系网易云信技术支持工程师获取详情。
* @param {String} context.server_config.channel_server 获取通道信息服务器。
* @param {String} context.server_config.statistics_server 统计上报服务器。
* @param {String} context.server_config.room_server roomServer 服务器。
* @param {String} context.server_config.compat_server 兼容性配置服务器
* @param {String} context.server_config.nos_lbs_server nos 域名解析服务器
* @param {String} context.server_config.nos_upload_sever 默认 nos 上传服务器
* @param {String} context.server_config.nos_token_server 获取 NOS token 服务器
* @param {Boolean} context.server_config.use_ipv6 是否使用 IPv6(默认 false)
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
initialize(context: NERtcEngineContext): number {
return this.nertcEngine.initialize(context);
}
/**
* 释放资源。
*/
release(): void {
return this.nertcEngine.release();
}
/**
* 设置参会者角色
* <pre>
* {@link NERtcEngine#setClientRole} 接口用于在直播场景中设置用户角色。默认情况下用户以主播角色加入房间。
* 在加入房间前,用户需要调用 setClientRole 接口设置本端模式为观众或主播模式。在加入房间后,用户可以通过本接口切换用户模式。
* 用户角色支持设置为主播或观众,主播和观众的权限不同。默认情况下用户以主播角色加入房间。
* 可以在通话前后设置,通话前设置会在加入频道之后生效。如果设置观众模式。则会停止音视频设备。
* </pre>
* @param {number} role 参会者模式
* <pre>
* - 主播(0):可以开关摄像头等设备、可以发布流、可以操作互动直播推流相关接口、上下线对其他房间内用户可见
* - 观众(1):不可以开关摄像头等设备、不可以发布流、不可以操作互动直播推流相关接口、上下线对其他房间内用户不可见
* </pre>
* @fires NERtcEngine#onClientRoleChanged
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setClientRole(role: NERtcClientRole): number {
return this.nertcEngine.setClientRole(role);
}
/**
* 设置通话模式
* <pre>
* 必须在加入通话前设置,开始通话后设置无效,结束通话后保留之前的设置。
* </pre>
* @param {number} profile 场景模式
* <pre>
* - 通话场景(0)
* - 直播推流场景(1)
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setChannelProfile(profile: NERtcChannelProfileType): number {
return this.nertcEngine.setChannelProfile(profile);
}
/**
* 加入频道。如果频道还未创建,会自动尝试创建频道。
* <pre>
* 该方法让用户加入通话频道,在同一个频道内的用户可以互相通话,多个用户加入同一个频道,可以群聊。使用不同 App Key 的 App 是不能互通的。如果已在通话中,用户必须调用 {@link NERtcEngine#leaveChannel} 退出当前通话,才能进入下一个频道。
* 频道内每个用户的用户 ID 必须是唯一的。
* </pre>
* @param {String} token 动态秘钥。安全要求不高: 将值设为 空字符串。安全要求高:将值设置为 Token。如果您已经启用了 App Certificate, 请务必使用 Token。
* @param {String} channelName 标识通话的频道名称,长度在 64 字节以内的字符串。以下为支持的字符集范围(共 89 个字符): a-z, A-Z, 0-9, space, !#$%&()+-:;≤.,>? @[]^_{|}~”
* @param {number} uid 用户 ID。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
joinChannel(token: String, channelName: String, uid: number): number {
return this.nertcEngine.joinChannel(token, channelName, uid);
}
/**
* 加入频道。如果频道还未创建,会自动尝试创建频道。
* @since V5.4.0
* <pre>
* 该方法让用户加入通话频道,在同一个频道内的用户可以互相通话,多个用户加入同一个频道,可以群聊。使用不同 App Key 的 App 是不能互通的。如果已在通话中,用户必须调用 {@link NERtcEngine#leaveChannel} 退出当前通话,才能进入下一个频道。
* 频道内每个用户的用户 ID 必须是唯一的。
* </pre>
* @param {String} token 动态秘钥。安全要求不高: 将值设为 空字符串。安全要求高:将值设置为 Token。如果您已经启用了 App Certificate, 请务必使用 Token。
* @param {String} channelName 标识通话的频道名称,长度在 64 字节以内的字符串。以下为支持的字符集范围(共 89 个字符): a-z, A-Z, 0-9, space, !#$%&()+-:;≤.,>? @[]^_{|}~”
* @param {number} uid 用户 ID。
* @param {Object} channelOptions 加入音视频房间时的一些可选信息。
* @param {string} channelOptions.custom_info 自定义信息,最长支持 127 个字符。
* @param {string} channelOptions.permission_key 权限密钥。能控制通话时长及媒体权限能力。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
joinChannelWithOptions(token: string, channelName: string, uid: number, channelOptions: NERtcJoinChannelOptions): number {
return this.nertcEngine.joinChannelWithOptions(token, channelName, uid, channelOptions);
}
/**
* 离开频道。
* <pre>
* 离开频道,即挂断或退出通话。
* 当调用 {@link NERtcEngine#joinChannel} 方法后,必须调用 {@link NERtcEngine#leaveChannel} 结束通话,否则无法开始下一次通话。不管当前是否在通话中,都可以调用 leaveChannel,没有副作用。该方法会把会话相关的所有资源释放掉。
* 该方法是异步操作,调用返回时并没有真正退出频道。在真正退出频道后,SDK 会触发 onLeaveChannel 事件。
* 如果您调用了 {@link NERtcEngine#leaveChannel} 后立即调用 {@link NERtcEngine#release} , SDK 将无法触发 onLeaveChannel 事件。
* </pre>
* @fires NERtcEngine#onLeaveChannel
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
leaveChannel(): number {
return this.nertcEngine.leaveChannel();
}
/**
* 开启或关闭本地语音采集或处理
* <pre>
* 该方法可以重新开启本地语音功能,重新开始本地音频采集及处理。
* 该方法不影响接收或播放远端音频流。
* <b>NOTE:</b>
* - 该方法与 {@link NERtcEngine#muteLocalAudioStream} 的区别在于:
* - {@link NERtcEngine#enableLocalAudio}: 开启本地语音采集及处理
* - {@link NERtcEngine#muteLocalAudioStream}: 停止或继续发送本地音频流
* 该方法设置内部引擎为启用状态,在 {@link NERtcEngine#leaveChannel} 后仍然有效。
* </pre>
* @param {Boolean} enabled
* <pre>
* - true: 重新开启本地语音功能,即开启本地语音采集或处理(默认)
* - false: 关闭本地语音功能,即停止本地语音采集或处理
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
enableLocalAudio(enabled: Boolean): number {
return this.nertcEngine.enableLocalAudio(enabled);
}
/**
* 设置本地视图。
* <pre>
* 该方法设置本地视频显示信息。App 通过调用此接口绑定本地视频流的显示视窗(view)。在 App 开发中,通常在初始化后调用该方法进行本地视频设置,然后再加入频道。
* </pre>
* @param {Object} canvas 视频画布信息
* @param {number} canvas.mode 视频画布缩放模式
* <pre>
* - 0 视频尺寸等比缩放。优先保证视频内容全部显示。因视频尺寸与显示视窗尺寸不一致造成的视窗未被填满的区域填充黑色。
* - 1 视频尺寸非等比缩放。保证视频内容全部显示,且填满视窗。
* - 2 视频尺寸等比缩放。优先保证视窗被填满。因视频尺寸与显示视窗尺寸不一致而多出的视频将被截掉。
* </pre>
* @param {Element} canvas.view 视频画布对象
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setupLocalVideoCanvas(canvas: NERtcVideoCanvas): number {
if (canvas.view) {
//bind
this.initRender('local', canvas.view);
this.setRenderMode('local', canvas.mode);
return this.nertcEngine.setupVideoCanvas(0, true);
} else {
//unbind
this.destroyRender('local');
return this.nertcEngine.setupVideoCanvas(0, false);
}
}
/**
* 设置远端用户视图。
* <pre>
* 该方法绑定远端用户和显示视图,即设定 uid 指定的用户用哪个视图显示。调用该接口时需要指定远端视频的 uid,一般可以在用户加入后设置好。
* 如果 App 不能事先知道对方的 uid,可以在 APP 收到 onUserJoined 事件时设置。
* 退出频道后,SDK 会把远端用户的绑定关系清除掉。
* </pre>
* @param {number} uid 远端用户 ID。
* @param {Object} canvas 视频画布信息
* @param {number} canvas.mode 视频画布缩放模式
* <pre>
* - 0 视频尺寸等比缩放。优先保证视频内容全部显示。因视频尺寸与显示视窗尺寸不一致造成的视窗未被填满的区域填充黑色。
* - 1 视频尺寸非等比缩放。保证视频内容全部显示,且填满视窗。
* - 2 视频尺寸等比缩放。优先保证视窗被填满。因视频尺寸与显示视窗尺寸不一致而多出的视频将被截掉。
* </pre>
* @param {Element} canvas.view 视频画布对象
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setupRemoteVideoCanvas(uid: number, canvas: NERtcVideoCanvas): number {
if (canvas.view) {
//bind
this.initRender(uid, canvas.view);
this.setRenderMode(uid, canvas.mode);
return this.nertcEngine.setupVideoCanvas(uid, true);
} else {
//unbind
this.destroyRender(uid);
return this.nertcEngine.setupVideoCanvas(uid, false);
}
}
/**
* 在指定用户的画布上截图。
* @param {'local'|number} uid 指定用户的 uid,其中在本地用户画布上截图时,此参数为 local。
* @param {NERtcVideoStreamType} streamType 视频流类型。
* <pre>
* - 0:视频流主流。
* - 1:视频流辅流。
* </pre>
* @returns string 返回 base64 截图数据。
*/
captureImageByUid(uid: 'local' | number, streamType: NERtcVideoStreamType = NERtcVideoStreamType.kNERtcVideoStreamMain): string {
return this.captureRender(uid, streamType)
}
/**
* 开启或关闭本地视频采集和渲染
* <pre>
* 该方法启用本地视频采集功能。
* 该方法设置内部引擎为启用状态,在 {@link NERtcEngine#leaveChannel} 后仍然有效。
* </pre>
* @param {boolean} enabled 是否启用本地视频:
* <pre>
* - true:开启本地视频采集和渲染 (默认)。
* - false:关闭使用本地摄像头设备。关闭后,远端用户会接收不到本地用户的视频流。但本地用户依然可以接收远端用户的视频流。设置为 false 时,该方法不需要本地有摄像头。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
enableLocalVideo(enabled: Boolean): number {
return this.nertcEngine.enableLocalVideo(enabled);
}
/**
* 开启或关闭本地视频采集和渲染
* @since V5.4.0
* <pre>
* 该方法启用本地视频采集功能。
* 该方法设置内部引擎为启用状态,在 {@link NERtcEngine#leaveChannel} 后仍然有效。
* </pre>
* @param {number} streamType 视频通道类型:
* <pre>
* - 0:主流。
* - 1:辅流。
* </pre>
* @param {boolean} enabled 是否启用本地视频:
* <pre>
* - true:开启本地视频采集和渲染 (默认)。
* - false:关闭使用本地摄像头设备。关闭后,远端用户会接收不到本地用户的视频流。但本地用户依然可以接收远端用户的视频流。设置为 false 时,该方法不需要本地有摄像头。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
enableLocalVideoWithType(streamType: NERtcVideoStreamType, enabled: boolean): number {
return this.nertcEngine.enableLocalVideoWithType(streamType, enabled);
}
/**
* 订阅 / 取消订阅指定远端用户的视频流。对方打开视频后需要主动订阅
* @param {number} uid 指定用户的用户 ID。
* @param {number} type 流类型:
* <pre>
* - 0 默认大流
* - 1 小流
* - 2 不订阅
* </pre>
* @param {boolean} subscribe
* <pre>
* - true:订阅指定远端用户的视频流。
* - false:取消订阅指定远端用户的视频流。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
subscribeRemoteVideoStream(uid: number, type: NERtcRemoteVideoStreamType, subscribe: Boolean): number {
return this.nertcEngine.subscribeRemoteVideoStream(uid, type, subscribe);
}
/**
* 获取当前网络状态。
* @returns {number}
* <pre>
* - 1 没加入频道。
* - 2 正在加入频道。
* - 3 加入频道成功。
* - 4 正在尝试重新加入频道。
* - 5 加入频道失败。
* </pre>
*/
getConnectionState(): number {
return this.nertcEngine.getConnectionState();
}
/**
* 开关本地音频发送。该方法用于允许/禁止往网络发送本地音频流。
* <pre>
* 该方法不影响录音状态,因为并没有禁用录音设备。
* </pre>
* @param {boolean} mute 静音/取消静音:
* <pre>
* - true: 静音本地音频
* - false: 取消静音本地音频(默认)
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
muteLocalAudioStream(enabled: Boolean): number {
return this.nertcEngine.muteLocalAudioStream(enabled);
}
/**
* 开启或关闭音频辅流。
* @since V5.4.0
* <pre>
* 开启时远端会收到 onUserSubStreamAudioStart,关闭时远端会收到 onUserSubStreamAudioStop。
* <b>NOTE:</b>
* - 该方法设置内部引擎为启用状态,在{@link NERtcEngine#leaveChannel}后仍然有效。
* </pre>
* @param {boolean} enabled 是否开启音频辅流:
* <pre>
* - true:开启音频辅流。
* - false:关闭音频辅流。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
enableLocalSubStreamAudio(enabled: boolean): number {
return this.nertcEngine.enableLocalSubStreamAudio(enabled);
}
/**
* 静音或解除静音本地上行的音频辅流。
* @since V5.4.0
* <pre>
* <b>NOTE:</b>
* - 静音状态会在通话结束后被重置为非静音。
* - 该方法仅可在加入房间后调用。
* </pre>
* @param {boolean} mute 是否静音本地音频辅流发送。
* <pre>
* - true:静音本地音频辅流(默认)。
* - false:取消静音本地音频辅流。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
muteLocalSubStreamAudio(enabled: boolean): number {
return this.nertcEngine.muteLocalSubStreamAudio(enabled);
}
/**
* 设置音频编码属性。
* <pre>
* <b>NOTE:</b>
* - 该方法需要在 {@link NERtcEngine#joinChannel} 之前设置好,{@link NERtcEngine#joinChannel} 之后设置不生效。
* - 音乐场景下,建议将 profile 设置为 4.
* @param {number} profile 设置采样率,码率,编码模式和声道数:
* <pre>
* - 0 默认设置。Speech 场景下为 1,Music 场景下为 2
* - 1 普通质量的音频编码,16000Hz,20Kbps
* - 2 普通质量的音频编码,16000Hz,32Kbps
* - 3 中等质量的音频编码,48000Hz,32Kbps
* - 4 中等质量的立体声编码,48000Hz * 2,64Kbps
* - 5 高质量的音频编码,48000Hz,64Kbps
* - 6 高质量的立体声编码,48000Hz * 2,128Kbps
* </pre>
* @param {number} scenario 设置音频应用场景:
* <pre>
* - 0: 默认设置:通过{@link NERtcEngine#setChannelProfile}设置通话模式时为语音场景(1),直播推流模式时为音乐场景(2)。
* - 1: 语音场景. profile 推荐使用 2 及以下
* - 2:音乐场景。profile 推荐使用 3 及以上
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setAudioProfile(profile: NERtcAudioProfileType, scenario: NERtcAudioScenarioType): number {
return this.nertcEngine.setAudioProfile(profile, scenario);
}
/**
* 订阅/取消订阅指定音频主流。
* @param {number} uid 指定用户的 ID
* @param {boolean} subscribe
* <pre>
* - true:订阅指定音频主流(默认)。
* - false:取消订阅指定音频主流。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
subscribeRemoteAudioStream(uid: number, enabled: Boolean): number {
return this.nertcEngine.subscribeRemoteAudioStream(uid, enabled);
}
/**
* 订阅/取消订阅指定音频辅流
* @since V5.4.0
* @param {number} uid 指定用户的 ID
* @param {boolean} subscribe
* <pre>
* - true:订阅指定音频辅流(默认)。
* - false:取消订阅指定音频辅流。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
subscribeRemoteSubStreamAudio(uid: number, subscribe: boolean): number {
return this.nertcEngine.subscribeRemoteSubStreamAudio(uid, subscribe);
}
/**
* 取消或恢复订阅所有远端用户的音频主流。
* @since V5.4.0
* <pre>
* 加入房间时,默认订阅所有远端用户的音频主流。
* <b>NOTE:</b>
* - 设置该方法的 subscribe 参数为 true 后,对后续加入房间的用户同样生效。
* - 在开启自动订阅(默认)时,设置该方法的 subscribe 参数为 false 可以实现取消订阅所有远端用户的音频流,但此时无法再调用{@link NERtcEngine#subscribeRemoteAudioStream}方法单独订阅指定远端用户的音频流。
* </pre>
* @param {boolean} subscribe
* <pre>
* - true:订阅所有远端用户的音频主流。
* - false:取消订阅所有远端用户的音频主流。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
subscribeAllRemoteAudioStream(subscribe: boolean): number {
return this.nertcEngine.subscribeAllRemoteAudioStream(subscribe);
}
/**
* 设置自己的音频只能被房间内指定的人订阅。
* @since V5.4.0
* <pre>
* 默认房间所有其他人都可以订阅自己的音频。
* <b>NOTE:</b>
* - 此接口需要在加入房间成功后调用。
* - 对于调用接口时不在房间的 uid 不生效。
* </pre>
* @param {Array<Number>} uids 用户 ID 数组
* @param {number} size 数组长度
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setAudioSubscribeOnlyBy(uids: Array<Number>, size: number): number { //[12, 34, 56]
return this.nertcEngine.setAudioSubscribeOnlyBy(uids, size);
}
/**
* 您可以调用该方法指定只订阅的音频流。
* <pre>
* - 此接口需要在加入房间成功后调用。
* - 对于调用接口时不在房间的 uid 不生效。
* </pre>
* @param {Array<Number>} uids 只订阅此用户 uid 列表 的音频.此列表为全量列表。如果列表为空或 null,取消订阅白名单。例如:[uid1,uid2...]。
* @param {number} size 数组长度
* @return {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setSubscribeAudioAllowlist(uids: Array<Number>, size: number): number {
return this.nertcEngine.setSubscribeAudioAllowlist(uids, size);
}
/**
* 您可以调用该方法指定不订阅的音频流。
* <pre>
* - 此接口需要在加入房间成功后调用。
* - 对于调用接口时不在房间的 uid 不生效。
* </pre>
* @param {number} audioStreamType 音频流类型。
* <pre>
* - 0: 主流
* - 1: 辅流
* </pre>
* @param {Array<Number>} uids 只订阅此用户 uid 列表 的音频.此列表为全量列表。如果列表为空或 null,取消订阅白名单。例如:[uid1,uid2...]。
* @param {number} size 数组长度
* @return {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setSubscribeAudioBlocklist(audioStreamType: number, uids: Array<Number>, size: number): number {
return this.nertcEngine.setSubscribeAudioBlocklist(audioStreamType, uids, size);
}
/**
* 开启精准对齐。
* @since V5.4.0
* <pre>
* 通过此接口可以实现精准对齐功能,对齐本地系统与服务端的时间。
* <b>NOTE:</b>
* - 请在引擎初始化之后调用此接口,且该方法仅可在加入房间前调用。
* - 适用于 KTV 实时合唱的场景。
* </pre>
* @param {boolean} enable 是否开启精准对齐功能:
* <pre>
* true:开启精准对齐功能。
* false:关闭精准对齐功能。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setStreamAlignmentProperty(enable: boolean): number {
return this.nertcEngine.setStreamAlignmentProperty(enable);
}
/**
* 获取本地系统时间与服务端时间差值。
* @since V5.4.0
* <pre>
* 可以用于做时间对齐,通过 (毫秒级系统时间 - offset) 可能得到当前服务端时间。
* </pre>
* @returns {number}
* <pre>
* - 本地与服务端时间差值,单位为毫秒(ms)。如果没有成功加入音视频房间,返回 0。
* </pre>
*/
getNtpTimeOffset(): number {
return this.nertcEngine.getNtpTimeOffset();
}
/**
* 设置本地摄像头的视频主流采集配置。
* @since V5.4.0
* <pre>
* 通过此接口可以设置本地摄像头采集的主流视频宽度、高度、旋转角度等。
* <b>NOTE:</b>
* - 纯音频 SDK 禁用该接口。
* - 该方法仅适用于视频主流。
* - 该方法支持在加入房间后动态调用,设置成功后,会自动重启摄像头采集模块。
* - 若系统相机不支持您设置的分辨率,会自动调整为最相近一档的分辨率,因此建议您设置为常规标准的分辨率。
* - 设置较高的采集分辨率会增加性能消耗,例如 CPU 和内存占用等,尤其是在开启视频前处理的场景下。
* </pre>
* @param {object} config 摄像头采集配置:
* @param {number} config.captureWidth 本地采集的视频宽度,单位为 px。
* @param {number} config.captureHeight 本地采集的视频高度,单位为 px。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setCameraCaptureConfig(config: NERtcCameraCaptureConfig): number {
return this.nertcEngine.setCameraCaptureConfig(config);
}
/**
* 设置本地摄像头的视频主流或辅流采集配置。
* @since V5.4.0
* <pre>
* 通过此接口可以设置本地摄像头采集的主流或辅流视频宽度、高度、旋转角度等。
* <b>NOTE:</b>
* - 纯音频 SDK 禁用该接口。
* - 调用该接口设置成功后,会自动重启摄像头采集模块。
* </pre>
* @param {NERtcVideoStreamType} streamType 视频通道类型。
* <pre>
* - 0:主流。
* - 1:辅流。
* </pre>
* @param {object} config 摄像头采集配置:
* @param {number} config.captureWidth 本地采集的视频宽度,单位为 px。
* @param {number} config.captureHeight 本地采集的视频高度,单位为 px。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setCameraCaptureConfigWithType(streamType: NERtcVideoStreamType, config: NERtcCameraCaptureConfig): number {
return this.nertcEngine.setCameraCaptureConfigWithType(streamType, config);
}
/**
* 设置视频配置。
* <pre>
* 该方法设置视频配置。每个属性对应一套视频参数,如分辨率等,会在摄像头重启后生效。所有设置的参数均为理想情况下的最大值。当视频引擎因网络环境等原因无法达到设置的分辨率的最大值时,会取最接近最大值的那个值。
* </pre>
* @param {object} config 视频配置:
* @param {number} config.max_profile 视频编码的分辨率,用于衡量编码质量:
* <pre>
* - 0 160x90/120, 15fps
* - 1 320x180/240, 15fps
* - 2 640x360/480, 30fps
* - 3 1280x720, 30fps
* - 4 1920x1080, 30fps
* </pre>
* @param {number} config.width 视频编码自定义分辨率之宽度。width 为 0 表示使用 max_profile
* @param {number} config.height 视频编码自定义分辨率之高度。height 为 0 表示使用 max_profile
* @param {number} config.crop_mode 视频画面裁剪模式:
* <pre>
* - 0 Device Defalut
* - 1 16:9
* - 2 4:3
* - 3 1:1
* </pre>
* @param {number} config.framerate 视频帧率:
* <pre>
* - 0 默认帧率
* - 7 7 帧每秒
* - 10 10 帧每秒
* - 15 15 帧每秒
* - 24 24 帧每秒
* - 30 30 帧每秒
* - 60 60 帧每秒
* </pre>
* @param {number} config.min_framerate 视频最小帧率:
* <pre>
* - 0 默认帧率
* - 7 7 帧每秒
* - 10 10 帧每秒
* - 15 15 帧每秒
* - 24 24 帧每秒
* - 30 30 帧每秒
* </pre>
* @param {number} [config.bitrate=0] 视频编码码率 kbps,取 0 时使用默认值
* @param {number} [config.min_bitrate=0] 视频编码码率下限 kbps,取 0 时使用默认值
* @param {number} config.degradation_preference 编码策略:
* <pre>
* - 0 使用引擎推荐值。通话场景使用平衡模式,直播推流场景使用清晰优先
* - 1 帧率优先
* - 2 清晰度优先
* - 3 平衡模式
* </pre>
* @param {number} config.mirror_mode 设置本地视频编码的镜像模式,即本地发送视频的镜像模式,只影响远端用户看到的视频画面:
* <pre>
* - 0 Windows/macOS SDK 启用镜像模式。在 iOS/Android 平台中:如果您使用前置摄像头,SDK 默认启用镜像模式;如果您使用后置摄像头,SDK 默认关闭镜像模式。
* - 1 启用镜像模式。
* - 2 清晰度优先
* - 3 关闭镜像模式(默认)。
* </pre>
* @param {number} config.orientation_mode 编码策略:
* <pre>
* - 0 该模式下 SDK 输出的视频方向与采集到的视频方向一致。接收端会根据收到的视频旋转信息对视频进行旋转(默认)。
* - 1 该模式下 SDK 固定输出横屏模式的视频。如果采集到的视频是竖屏模式,则视频编码器会对其进行裁剪。
* - 2 该模式下 SDK 固定输出竖屏模式的视频,如果采集到的视频是横屏模式,则视频编码器会对其进行裁剪。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setVideoConfig(config: NERtcVideoConfig): number {
return this.nertcEngine.setVideoConfig(config);
}
/**
* 设置视频配置。
* @since V5.4.0
* <pre>
* 该方法设置视频配置。每个属性对应一套视频参数,如分辨率等,会在摄像头重启后生效。所有设置的参数均为理想情况下的最大值。当视频引擎因网络环境等原因无法达到设置的分辨率的最大值时,会取最接近最大值的那个值。
* </pre>
* @param {number} streamType 视频通道类型。
* <pre>
* - 0:主流。
* - 1:辅流。
* </pre>
* @param {object} config 视频配置:
* @param {number} config.max_profile 视频编码的分辨率,用于衡量编码质量:
* <pre>
* - 0 160x90/120, 15fps
* - 1 320x180/240, 15fps
* - 2 640x360/480, 30fps
* - 3 1280x720, 30fps
* - 4 1920x1080, 30fps
* </pre>
* @param {number} config.width 视频编码自定义分辨率之宽度。width 为 0 表示使用 max_profile
* @param {number} config.height 视频编码自定义分辨率之高度。height 为 0 表示使用 max_profile
* @param {number} config.crop_mode 视频画面裁剪模式:
* <pre>
* - 0 Device Defalut
* - 1 16:9
* - 2 4:3
* - 3 1:1
* </pre>
* @param {number} config.framerate 视频帧率:
* <pre>
* - 0 默认帧率
* - 7 7 帧每秒
* - 10 10 帧每秒
* - 15 15 帧每秒
* - 24 24 帧每秒
* - 30 30 帧每秒
* - 60 60 帧每秒
* </pre>
* @param {number} config.min_framerate 视频最小帧率:
* <pre>
* - 0 默认帧率
* - 7 7 帧每秒
* - 10 10 帧每秒
* - 15 15 帧每秒
* - 24 24 帧每秒
* - 30 30 帧每秒
* </pre>
* @param {number} [config.bitrate=0] 视频编码码率 kbps,取 0 时使用默认值
* @param {number} [config.min_bitrate=0] 视频编码码率下限 kbps,取 0 时使用默认值
* @param {number} config.degradation_preference 编码策略:
* <pre>
* - 0 使用引擎推荐值。通话场景使用平衡模式,直播推流场景使用清晰优先
* - 1 帧率优先
* - 2 清晰度优先
* - 3 平衡模式
* </pre>
* @param {number} config.mirror_mode 设置本地视频编码的镜像模式,即本地发送视频的镜像模式,只影响远端用户看到的视频画面:
* <pre>
* - 0 Windows/macOS SDK 启用镜像模式。
* - 1 启用镜像模式。
* - 2 (默认)关闭镜像模式。
* </pre>
* @param {NERtcVideoOutputOrientationMode} config.orientation_mode 编码策略:
* <pre>
* - 0 该模式下 SDK 输出的视频方向与采集到的视频方向一致。接收端会根据收到的视频旋转信息对视频进行旋转(默认)。
* - 1 该模式下 SDK 固定输出横屏模式的视频。如果采集到的视频是竖屏模式,则视频编码器会对其进行裁剪。
* - 2 该模式下 SDK 固定输出竖屏模式的视频,如果采集到的视频是横屏模式,则视频编码器会对其进行裁剪。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setVideoConfigWithType(streamType: NERtcVideoStreamType, config: NERtcVideoConfig): number {
return this.nertcEngine.setVideoConfigWithType(streamType, config);
}
/**
* 设置视频双流发送。
* <pre>
* 调用该方法控制是否支持发送双流,只对摄像头数据生效,自定义输入、取屏等无效。设置后,会在摄像头重启后生效。
* </pre>
* @param {boolean} enable
* <pre>
* - true: 双流发送(默认)
* - false: 只发送一个流
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
enableDualStreamMode(enabled: Boolean): number {
return this.nertcEngine.enableDualStreamMode(enabled);
}
/**
* 设置本地辅流视图。
* <pre>
* 该方法设置本地辅流视频显示信息。App 通过调用此接口绑定本地辅流的显示视窗(view)。在 App 开发中,通常在初始化后调用该方法进行本地视频设置,然后再加入频道。
* </pre>
* @param {Object} canvas 视频画布信息
* @param {number} canvas.mode 视频显示模式
* <pre>
* - 0 视频尺寸等比缩放。优先保证视频内容全部显示。因视频尺寸与显示视窗尺寸不一致造成的视窗未被填满的区域填充黑色。
* - 1 视频尺寸非等比缩放。保证视频内容全部显示,且填满视窗。
* - 2 视频尺寸等比缩放。优先保证视窗被填满。因视频尺寸与显示视窗尺寸不一致而多出的视频将被截掉。
* </pre>
* @param {Element} canvas.view 视频画布对象
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setupLocalSubStreamVideoCanvas(canvas: NERtcVideoCanvas): number {
if (canvas.view) {
//bind
this.initSubStreamRender('local', canvas.view);
this.setSubStreamRenderMode('local', canvas.mode);
return this.nertcEngine.setupSubStreamVideoCanvas(0, true);
} else {
//unbind
this.destroySubStreamRender('local');
return this.nertcEngine.setupSubStreamVideoCanvas(0, false);
}
}
/**
* 设置本地视图/远端视图显示模式。
* <pre>
* 该方法设置视图显示模式。App 可以多次调用此方法更改显示模式。
* </pre>
* @param {(string|number)} uid
* <pre>
* 'local':本地视图
* {number}:远端用户 ID。
* </pre>
* @param {number} mode 视频显示模式:
* <pre>
* - 0 视频尺寸等比缩放。优先保证视频内容全部显示。因视频尺寸与显示视窗尺寸不一致造成的视窗未被填满的区域填充黑色。
* - 1 视频尺寸非等比缩放。保证视频内容全部显示,且填满视窗。
* - 2 视频尺寸等比缩放。优先保证视窗被填满。因视频尺寸与显示视窗尺寸不一致而多出的视频将被截掉。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setRenderMode(uid: 'local' | number, mode: NERtcVideoScalingMode): number {
if (this.renderers.has(String(uid))) {
let renderer = this.renderers.get(String(uid));
(renderer as IRenderer).setContentMode(mode);
return 0;
}
else {
return -1;
}
}
/**
* 设置辅流视图/远端辅流视图显示模式。
* <pre>
* 该方法设置视图显示模式。App 可以多次调用此方法更改显示模式。
* </pre>
* @param {(string|number)} uid
* <pre>
* 'local':本地辅流视图
* {number}:远端辅流用户 ID。
* </pre>
* @param {number} mode 视频显示模式:
* <pre>
* - 0 视频尺寸等比缩放。优先保证视频内容全部显示。因视频尺寸与显示视窗尺寸不一致造成的视窗未被填满的区域填充黑色。
* - 1 视频尺寸非等比缩放。保证视频内容全部显示,且填满视窗。
* - 2 视频尺寸等比缩放。优先保证视窗被填满。因视频尺寸与显示视窗尺寸不一致而多出的视频将被截掉。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setSubStreamRenderMode(uid: 'local' | number, mode: NERtcVideoScalingMode): number {
if (this.substreamRenderers.has(String(uid))) {
let renderer = this.substreamRenderers.get(String(uid));
(renderer as IRenderer).setContentMode(mode);
return 0;
}
else {
return -1;
}
}
/**
* 设置本地视频镜像模式。
* <pre>
* 该方法设置本地视频镜像模式。App 可以多次调用此方法更改镜像模式。
* </pre>
* @param {number} mode 视频镜像模式:
* <pre>
* - 0 默认关闭镜像模式。
* - 1 启用镜像模式。
* - 2 关闭镜像模式。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setLocalVideoMirrorMode(mode: NERtcVideoMirrorMode): number {
return this.nertcEngine.setLocalVideoMirrorMode(mode);
}
/**
* 设置本地视频镜像模式。
* @since V5.4.0
* <pre>
* 通过此接口可以设置本地视频是否开启镜像模式,即画面是否左右翻转。
* <b>NOTE:</b>
* - 纯音频 SDK 禁用该接口
* - 本地视频画布的镜像模式仅影响本地用户所见,不影响远端用户所见。您的应用层可以多次调用此方法更改镜像模式。
* </pre>
* @param {number} streamType 视频通道类型。
* <pre>
* - 0:主流。
* - 1:辅流。
* </pre>
* @param {number} mode 视频镜像模式:
* <pre>
* - 0 Windows/macOS SDK 启用镜像模式。
* - 1 启用镜像模式。
* - 2 (默认)关闭镜像模式。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setLocalVideoMirrorModeWithType(streamType: NERtcVideoStreamType, mode: NERtcVideoMirrorMode): number {
return this.nertcEngine.setLocalVideoMirrorModeWithType(streamType, mode);
}
/**
* 设置远端用户辅流视图。
* <pre>
* 该方法绑定远端用户和辅流显示视图,即设定 uid 指定的用户用哪个视图显示。调用该接口时需要指定远端视频的 uid,一般可以在用户加入后设置好。
* <b>NODE:</b>
* - 如果 App 不能事先知道对方的 uid,可以通过{@link NERtcEngine#on}方法监听 onUserJoined 事件时设置。
* - 退出频道后,SDK 会把远端用户的绑定关系清除掉。
* </pre>
* @param {number} uid 远端用户 ID。
* @param {Object} canvas 视频画布信息
* @param {number} canvas.mode 视频显示模式
* <pre>
* - 0 视频尺寸等比缩放。优先保证视频内容全部显示。因视频尺寸与显示视窗尺寸不一致造成的视窗未被填满的区域填充黑色。
* - 1 视频尺寸非等比缩放。保证视频内容全部显示,且填满视窗。
* - 2 视频尺寸等比缩放。优先保证视窗被填满。因视频尺寸与显示视窗尺寸不一致而多出的视频将被截掉。
* </pre>
* @param {Element} canvas.view 视频画布对象
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setupRemoteSubStreamVideoCanvas(uid: number, canvas: NERtcVideoCanvas): number {
if (canvas.view) {
//bind
this.initSubStreamRender(uid, canvas.view);
this.setSubStreamRenderMode(uid, canvas.mode);
return this.nertcEngine.setupSubStreamVideoCanvas(uid, true);
} else {
//unbind
this.destroySubStreamRender(uid);
return this.nertcEngine.setupSubStreamVideoCanvas(uid, false);
}
}
/**
* 订阅 / 取消订阅指定远端用户的视频辅流。
* <pre>
* 对方打开视频后需要主动订阅
* <b>NOTE:</b>
* - 必须在远端加入房间后调用。
* - 必须先设置远端辅流画布。
* </pre>
* @param {number} uid 指定用户的用户 ID。
* @param {number} subscribe
* <pre>
* - true:订阅指定远端用户的视频流。
* - false:取消订阅指定远端用户的视频流。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
subscribeRemoteVideoSubStream(uid: number, sub: boolean): number {
return this.nertcEngine.subscribeRemoteVideoSubStream(uid, sub);
}
/**
* 开启视频预览。
* <pre>
* 该方法用于在进入频道前启动本地视频预览。调用该 API 前,必须:
* - 调用 {@link NERtcEngine#setupLocalVideoCanvas} 设置预览窗口;
* - 调用 {@link NERtcEngine#setVideoDevice} 前必须先设置设备 ID;
* <b>NOTE:</b> 启用了本地视频预览后,在进入频道前,本地预览必须先关闭,需要调用 {@link NERtcEngine#stopVideoPreview}。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
startVideoPreview(): number {
return this.nertcEngine.startVideoPreview();
}
/**
* 开启视频预览。
* @since V5.4.0
* <pre>
* 该方法用于在进入频道前启动本地视频预览。调用该 API 前,必须:
* - 调用 {@link NERtcEngine#setupLocalVideoCanvas} 设置预览窗口;
* - 调用 {@link NERtcEngine#setVideoDevice} 前必须先设置设备 ID;
* <b>NOTE:</b> 启用了本地视频预览后,在进入频道前,本地预览必须先关闭,需要调用 {@link NERtcEngine#stopVideoPreview}。
* </pre>
* @param {number} streamType 视频通道类型。
* <pre>
* - 0:主流。
* - 1:辅流。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
startVideoPreviewWithType(streamType: number): number {
return this.nertcEngine.startVideoPreviewWithType(streamType);
}
/**
* 停止视频预览。
* <pre>
* 通过此接口可以实现在预览本地视频后关闭预览。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
stopVideoPreview(): number {
return this.nertcEngine.stopVideoPreview();
}
/**
* 停止视频预览。
* <pre>
* 通过此接口可以实现在预览本地视频后关闭预览。
* </pre>
* @param {number} streamType 视频通道类型。
* <pre>
* - 0:主流。
* - 1:辅流。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
stopVideoPreviewWithType(streamType: number): number {
return this.nertcEngine.stopVideoPreviewWithType(streamType);
}
/**
* 开关本地视频发送。
* <pre>
* 调用该方法禁视频流时,SDK 不再发送本地视频流,但摄像头仍然处于工作状态。相比于 {@link NERtcEngine#enableLocalVideo} (false) 用于控制本地视频流发送的方法,该方法响应速度更快。该方法不影响本地视频流获取,没有禁用摄像头。
* </pre>
* @param {boolean} mute
* <pre>
* - true: 不发送本地视频流
* - false: 发送本地视频流(默认)
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
muteLocalVideoStream(enabled: Boolean): number {
return this.nertcEngine.muteLocalVideoStream(enabled);
}
/**
* 开关本地视频发送。
* <pre>
* 调用该方法禁视频流时,SDK 不再发送本地视频流,但摄像头仍然处于工作状态。相比于 {@link NERtcEngine#enableLocalVideo} (false) 用于控制本地视频流发送的方法,该方法响应速度更快。该方法不影响本地视频流获取,没有禁用摄像头。
* </pre>
* @param {number} streamType 视频通道类型。
* <pre>
* - 0:视频主流。
* - 1:视频辅流。
* </pre>
* @param {boolean} mute
* <pre>
* - true: 不发送本地视频流
* - false: 发送本地视频流(默认)
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
muteLocalVideoStreamWithType(streamType: number, enabled: boolean): number {
return this.nertcEngine.muteLocalVideoStreamWithType(streamType, enabled);
}
/**
* 通过 JSON 配置 SDK 提供技术预览或特别定制功能。以标准化方式公开 JSON 选项。
* @param {object} parameters JSON 字符串形式的参数
* @param {boolean} parameters.record_host_enabled
* <pre>
* - true 录制主讲人
* - false 不是录制主讲人
* </pre>
* @param {boolean} [parameters.record_audio_enabled=false] 启用服务器音频录制。默认值 false
* @param {boolean} [parameters.record_video_enabled=false] 启用服务器视频录制。默认值 false
* @param {number} parameters.record_type 录制类型:
* <pre>
* - 0 参与混合录制且录制单人文件
* - 1 参与混合录制
* - 2 只录单人文件
* </pre>
* @param {boolean} [parameters.auto_subscribe_audio=true] 其他用户打开音频时,自动订阅。默认值 true
* @param {boolean} [parameters.publish_self_stream_enabled=false] 开启旁路直播。默认值 false
* @param {number} [parameters.log_level=3] 日志级别,默认级别为 kNERtcLogLevelInfo。
* <pre>
* - 0 Fatal 级别日志信息
* - 1 Error 级别日志信息
* - 2 Warning 级别日志信息
* - 3 Info 级别日志信息。默认级别
* - 4 DetailInfo 级别日志信息
* - 5 Verbos 级别日志信息
* - 6 Debug 级别日志信息。如果您想获取最完整的日志,可以将日志级别设为该等级
* - 7 不输出日志信息
* </pre>
* @param {boolean} [parameters.audio_processing_aec_enable=true] AEC 开关,默认值 true
* @param {boolean} [parameters.audio_processing_agc_enable=true] AGC 开关,默认值 true
* @param {boolean} [parameters.audio_processing_ns_enable=true] NS 开关,默认值 true
* @param {boolean} [parameters.audio_processing_ai_ns_enable=false] AI NS 开关,建议通话前修改,默认值 false
* @param {boolean} [parameters.audio_processing_external_audiomix_enable=false] 输入混音开关,默认值 false
* @param {boolean} [parameters.audio_processing_earphone=false] 通知 SDK 是否使用耳机:
* <pre>
* - true: 使用耳机
* - false: 不使用耳机
* </pre>
* @param {number} [parameters.video_sendonpub_type=1] 设置视频发送策略,默认发送大流(1);通话前设置有效
* <pre>
* - 0 不主动发送数据流,被订阅后发送。
* - 1 主动发送大流。
* - 2 主动发送小流。
* - 3 主动发送大小流。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setParameters(parameters: String): number {
return this.nertcEngine.setParameters(parameters);
}
/**
* 以 String 的形式获取一些内部参数。
* @since V5.3.0
* <pre>
* <b>NOTE:</b>
* - 此接口为隐藏接口,需要特定参数及特定时机,详情请 [提交工单](https://app.yunxin.163.com/global/service/ticket/create) 联系网易云信技术支持工程师。
* - 请在初始化后调用该方法,且该方法在加入房间前后均可调用。
* </pre>
* @param {String} parameters 音视频通话的参数集合.
* @param {String} extra_info 额外的信息。
* @returns {String} 内部参数信息。
*/
getParameters(parameters: String, extra_info: String): String {
return this.nertcEngine.getParameters(parameters, extra_info);
}
// /**
// * 设置采集的音频格式。
// * @since V5.4.0
// * <pre>
// * <b>NOTE:</b>
// * - 请在初始化后调用该方法,且该方法在加入房间前后均可调用。
// * - 适用于需要监听音频 PCM 采集数据回调并指定回调的数据格式的场景。
// * - 若您希望使用音频的原始格式,format 参数传 NULL 即可。
// * </pre>
// * @param {object} format 音频帧请求格式
// * @param {Number} format.channels 音频声道数量:
// * <pre>
// * - 1 单声道
// * - 2 双声道
// * </pre>
// * @param {Number} format.sample_rate 采样率。
// * @param {number} format.mode 读写模式:
// * <pre>
// * 0 返回数据只读模式
// * 1 返回数据可读写
// * </pre>
// * @returns {number}
// * <pre>
// * - 0:方法调用成功。
// * - 其他:方法调用失败。
// * </pre>
// */
// setRecordingAudioFrameParameters(format: NERtcAudioFrameRequestFormat): number {
// return this.nertcEngine.setRecordingAudioFrameParameters(format);
// }
// /**
// * 设置音频播放回调的声音格式。
// * @since V5.4.0
// * <pre>
// * <b>NOTE:</b>
// * - 请在初始化后调用该方法,且该方法仅可在加入房间后调用。
// * - 适用于需要自行对待播放的声音进行二次处理的场景。
// * </pre>
// * @param {object} format 音频帧请求格式
// * @param {Number} format.channels 音频声道数量:
// * <pre>
// * - 1 单声道
// * - 2 双声道
// * </pre>
// * @param {Number} format.sample_rate 采样率。
// * @param {number} format.mode 读写模式:
// * <pre>
// * 0 返回数据只读模式
// * 1 返回数据可读写
// * </pre>
// * @returns {number}
// * <pre>
// * - 0:方法调用成功。
// * - 其他:方法调用失败。
// * </pre>
// */
// setPlaybackAudioFrameParameters(format: NERtcAudioFrameRequestFormat): number {
// return this.nertcEngine.setPlaybackAudioFrameParameters(format);
// }
// /**
// * 设置采集和播放声音混音后的音频数据采样率。
// * @since V5.4.0
// * <pre>
// * 通过本接口可以实现设置 onMixedAudioFrame 回调的混音音频采样率
// * <b>NOTE:</b>
// * - 请在初始化后调用该方法,且该方法在加入房间前后均可调用。
// * - 适用于需要获取本地用户和远端所有用户的声音的场景,比如通话录音的场景。
// * - 该方法设置内部引擎为启用状态,在离开房间后设置会重置为默认状态。
// * - 未调用该接口设置返回的音频数据格式时,回调中的采样率取默认值。
// * </pre>
// * @param {Number} sample_rate 采样率。
// * @returns {number}
// * <pre>
// * - 0:方法调用成功。
// * - 其他:方法调用失败。
// * </pre>
// */
// setMixedAudioFrameParameters(sample_rate: number): number {
// return this.nertcEngine.setMixedAudioFrameParameters(sample_rate);
// }
/**
* 开启音频 dump。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
startAudioDump(): number {
return this.nertcEngine.startAudioDump();
}
/**
* 开启音频 dump。
* @since V5.4.0
* @param {number} type 音频 dump 类型。
* <pre>
* - 0:仅输出.dump 文件(默认)。
* - 1:输出.dump 和.wav 文件。
* - 2: 仅输出.wav 文件.
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
startAudioDumpWithType(type: number): number {
return this.nertcEngine.startAudioDumpWithType(type);
}
/**
* 结束音频 dump。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
stopAudioDump(): number {
return this.nertcEngine.stopAudioDump();
}
/**
* 开始播放伴奏。
* <pre>
* 指定本地或在线音频文件来和录音设备采集的音频流进行混音。成功调用该方法后,可以通过{@link NERtcEngine#on}方法监听 onAudioMixingStateChanged 播放状态改变事件。
* 请在频道内调用该方法,如果在频道外调用该方法可能会出现问题。
* </pre>
* @param {object} option 创建混音任务配置的选项,包括混音任务类型、混音文件全路径或 URL 等。支持的音频格式包括:AAC、MP3 和 WAVE。
* @param {string} option.path 本地文件全路径或 URL <256 chars
* @param {number} [option.loop_count=1] 循环次数,<= 0, 表示无限循环,默认 1
* @param {boolean} [option.send_enabled=true] 是否可发送,默认为 true
* @param {number} [option.send_volume=100] 发送音量。最大为 100(默认)含义(0%-100%)
* @param {boolean} [option.playback_enabled=true] 是否可回放,默认为 true
* @param {number} [option.playback_volume=100] 回放音量。最大为 100(默认)
* @param {number} [option.start_timestamp] 音乐文件开始播放的时间,UTC 时间戳,即从 1970 年 1 月 1 日 0 点 0 分 0 秒开始到事件发生时的毫秒数。默认值为 0,表示立即播放。
* @param {number} [option.NERtcAudioStreamType] 伴音跟随音频主流还是辅流,默认跟随主流。
* @param {number} [option.progress_interval] 伴音播放进度回调间隔,单位 ms,取值范围为 100~10000, 默认 1000ms。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
startAudioMixing(opt: NERtcCreateAudioMixingOption): number {
return this.nertcEngine.startAudioMixing(opt);
}
/**
* 停止播放伴奏。
* <pre>
* 该方法停止播放伴奏。请在频道内调用该方法。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
stopAudioMixing(): number {
return this.nertcEngine.stopAudioMixing();
}
/**
* 暂停播放伴奏。
* <pre>
* 该方法暂停播放伴奏。请在频道内调用该方法。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
pauseAudioMixing(): number {
return this.nertcEngine.pauseAudioMixing();
}
/**
* 恢复播放伴奏。
* <pre>
* 该方法恢复混音,继续播放伴奏。请在频道内调用该方法。
* </pre>
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
resumeAudioMixing(): number {
return this.nertcEngine.resumeAudioMixing();
}
/**
* 调节伴奏发送音量。
* <pre>
* 该方法调节混音里伴奏的发送音量大小。请在频道内调用该方法。
* </pre>
* @param {number} volume 伴奏音量范围为 0~200。默认 100 为原始文件音量。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setAudioMixingSendVolume(volume: number): number {
return this.nertcEngine.setAudioMixingSendVolume(volume);
}
/**
* 获取伴奏发送音量。
* <pre>
* 该方法获取混音里伴奏的发送音量大小。请在频道内调用该方法。
* </pre>
* @returns {number}
* <pre>
* - >=0:伴奏发送音量。
* - 其他:方法调用失败。
* </pre>
*/
getAudioMixingSendVolume(): number {
return this.nertcEngine.getAudioMixingSendVolume();
}
/**
* 调节伴奏播放音量。
* <pre>
* 该方法调节混音里伴奏的播放音量大小。请在频道内调用该方法。
* </pre>
* @param {number} volume 伴奏音量范围为 0~200。默认 100 为原始文件音量。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setAudioMixingPlaybackVolume(volume: number): number {
return this.nertcEngine.setAudioMixingPlaybackVolume(volume);
}
/**
* 获取伴奏播放音量。
* <pre>
* 该方法获取混音里伴奏的播放音量大小。请在频道内调用该方法。
* </pre>
* @returns {number}
* <pre>
* - >= 0:伴奏播放音量。
* - 其他:方法调用失败。
* </pre>
*/
getAudioMixingPlaybackVolume(): number {
return this.nertcEngine.getAudioMixingPlaybackVolume();
}
/**
* 获取伴奏时长。
* <pre>
* 该方法获取伴奏时长,单位为毫秒。请在频道内调用该方法。
* </pre>
* @returns {number}
* <pre>
* - >=0:伴奏时长,单位为毫秒。
* - 其他:方法调用失败。
* </pre>
*/
getAudioMixingDuration(): number {
return this.nertcEngine.getAudioMixingDuration();
}
/**
* 获取音乐文件的播放进度。
* <pre>
* 该方法获取当前伴奏播放进度,单位为毫秒。请在频道内调用该方法。
* </pre>
* @returns {number}
* <pre>
* - >= 0:伴奏播放进度,单位为毫秒。
* - 其他:方法调用失败。
* </pre>
*/
getAudioMixingCurrentPosition(): number {
return this.nertcEngine.getAudioMixingCurrentPosition();
}
/**
* 设置音乐文件的播放位置。
* <pre>
* 该方法可以设置音频文件的播放位置,这样您可以根据实际情况播放文件,而非从头到尾播放整个文件。
* </pre>
* @param {number} pos 进度条位置,单位为毫秒。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setAudioMixingPosition(pos: number): number {
return this.nertcEngine.setAudioMixingPosition(pos);
}
/**
* 设置当前伴音文件的音调。
* @since v5.4.0
* <pre>
* 通过此接口可以实现当本地人声和播放的音乐文件混音时,仅调节音乐文件的音调。
* <b>NOTE:</b>
* - 当前伴音任务结束后,此接口的设置会恢复至默认。
* </pre>
* @param {number} pitch 当前伴音文件的音调。默认值为 0,即不调整音调,取值范围为 -12 ~ 12
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setAudioMixingPitch(pitch: number): number {
return this.nertcEngine.setAudioMixingPitch(pitch);
}
/**
* 获取当前伴音文件的音调。
* @since v5.4.0
* <pre>
* 请先调用 startAudioMixing 方法开启伴音。
* @returns {number} 当前伴音文件音调
*/
getAudioMixingPitch(): number {
return this.nertcEngine.getAudioMixingPitch();
}
/**
* 播放指定音效文件。
* <pre>
* 您可以多次调用该方法,通过传入不同的音效文件的 effect_id 和 option,同时播放多个音效文件,实现音效叠加。为获得最佳用户体验,网易云信建议同时播放的音效文件不要超过 3 个。成功调用该方法后,可以通过{@link NERtcEngine#on}方法监听 onAudioEffectFinished 播放结束事件。
* 请在频道内调用该方法,如果在频道外调用该方法可能会出现问题。
* </pre>
* @param {number} effectId 指定音效的 ID。每个音效均有唯一的 ID。
* @param {object[]} opt 创建音效任务配置的选项,包括混音任务类型、混音文件全路径或 URL 等。支持的音频格式包括:AAC、MP3 和 WAVE。
* @param {String} opt[].path 本地文件全路径或 URL <256 chars
* @param {number} [opt[].loop_count=1] 循环次数,<= 0, 表示无限循环,默认 1
* @param {boolean} [opt[].send_enabled=true] 是否可发送,默认为 true
* @param {number} [opt[].send_volume] 发送音量。最大为 100(默认)含义(0%-100%)
* @param {boolean} [opt[].playback_enabled=true] 是否可回放,默认为 true
* @param {number} [opt[].playback_volume] 回放音量。最大为 100(默认)
* @param {number} [opt[].start_timestamp] 音乐文件开始播放的时间,UTC 时间戳,即从 1970 年 1 月 1 日 0 点 0 分 0 秒开始到事件发生时的毫秒数。默认值为 0,表示立即播放。
* @param {number} [opt[].NERtcAudioStreamType] 伴音跟随音频主流还是辅流,默认跟随主流。
* @param {number} [opt[].progress_interval] 伴音播放进度回调间隔,单位 ms,取值范围为 100~10000, 默认 1000ms。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
playEffect(effectId: number, opt: Array<NERtcCreateAudioEffectOption>): number {
return this.nertcEngine.playEffect(effectId, opt);
}
/**
* 停止播放指定音效文件。
* <pre>
* 请在频道内调用该方法。
* </pre>
* @param {number} effectId 指定音效的 ID。每个音效均有唯一的 ID。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
stopEffect(effectId: number): number {
return this.nertcEngine.stopEffect(effectId);
}
/**
* 设置指定音效文件的音调。
* @since v5.4.0
* <pre>
* 通过此接口可以实现当本地人声和播放的音乐文件混音时,仅调节音乐文件的音调。
* <b>NOTE:</b>
* - 当前音效任务结束后,此接口的设置会恢复至默认。
* </pre>
* @param {number} 指定音效文件的 ID。每个音效文件均对应唯一的 ID。
* @param {number} pitch 当前音效文件的音调。默认值为 0,即不调整音调,取值范围为 -12 ~ 12。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
setEffectPitch(effectId: number, pitch: number): number {
return this.nertcEngine.setEffectPitch(effectId, pitch);
}
/**
* 获取指定音效文件的音调。
* @since v5.4.0
* <pre>
* 请先调用 playEffect 方法开启伴音。
* </pre>
* @returns {number} 当前音效文件音调
*/
getEffectPitch(effectId: number): number {
return this.nertcEngine.getEffectPitch(effectId);
}
/**
* 停止播放所有音效文件。
* @returns {number}
* <pre>
* - 0:方法调用成功。
* - 其他:方法调用失败。
* </pre>
*/
stopAllEffects(): number {
return this.nertcEngine.stopAllEffects();
}
/**
* 暂停音效文件播放。
* <pre>
* 请