发布和订阅
enableDualStreamMode [1/2]
在发送端开启或关闭双流模式。
public abstract int enableDualStreamMode(boolean enabled);
详情
- 视频大流:高分辨率、高帧率的视频流。
- 视频小流:低分辨率、低帧率的视频流。
开启双流模式后,你可以在收流端调用 setRemoteVideoStreamType [1/2] 选择接收视频大流或视频小流。
- 该方法适用于发送端发送的所有类型的流,包括且不限于来自摄像头采集的视频流、屏幕共享流、自定义采集的视频流。
- 如果需要在多频道场景下开启视频双流,可以调用 enableDualStreamModeEx 方法。
- 该方法可以在加入频道前后调用。
参数
- enabled
- 是否开启双流模式。
true
: 开启双流模式。false
: (默认) 关闭双流模式。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
enableDualStreamMode [2/2]
在发送端开启或关闭双流模式并设置视频小流。
public abstract int enableDualStreamMode(boolean enabled, SimulcastStreamConfig streamConfig);
详情
- 视频大流:高分辨率、高帧率的视频流。
- 视频小流:低分辨率、低帧率的视频流。
开启双流模式后,你可以在收流端调用 setRemoteVideoStreamType [1/2] 选择接收视频大流或视频小流。
- 该方法适用于发送端发送的所有类型的流,包括且不限于来自摄像头采集的视频流、屏幕共享流、自定义采集的视频流。
- 如果需要在多频道场景下开启视频双流,可以调用 enableDualStreamModeEx 方法。
- 该方法可以在加入频道前后调用。
参数
- enabled
- 是否开启双流模式:
true
: 开启双流模式。false
: (默认) 关闭双流模式。
- streamConfig
- 视频小流的配置。详见 SimulcastStreamConfig。信息当设置 mode 为 DISABLE_SIMULCAST_STREAM 时,再设置 streamConfig 不会生效。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。 详见错误码了解详情和解决建议。
enableDualStreamModeEx
在发送端开启或关闭双流模式。
public abstract int enableDualStreamModeEx(
boolean enabled, SimulcastStreamConfig streamConfig, RtcConnection connection);
详情
- 视频大流:高分辨率、高帧率的视频流。
- 视频小流:低分辨率、低帧率的视频流。
开启双流模式后,你可以在收流端调用 setRemoteVideoStreamType [1/2] 选择接收视频大流或视频小流。
参数
- enabled
- 是否开启双流模式:
true
: 开启双流模式。false
: (默认) 关闭双流模式。
- streamConfig
- 视频小流的配置。详见 SimulcastStreamConfig。信息当设置 mode 为 DISABLE_SIMULCAST_STREAM 时,再设置 streamConfig 不会生效。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。 详见错误码了解详情和解决建议。
muteAllRemoteAudioStreams
取消或恢复订阅所有远端用户的音频流。
public abstract int muteAllRemoteAudioStreams(boolean muted);
成功调用该方法后,本地用户会取消或恢复订阅所有远端用户的音频流,包括在调用该方法后加入频道的用户的音频流。
SDK 默认在加入频道时订阅所有远端用户的音频流,如果要修改此行为,可以在调用 joinChannel [2/2] 加入频道时设置 autoSubscribeAudio 为 false
,即可在加入频道时取消订阅所有用户的音频流。
调用时机
该方法需要在加入频道后调用。
调用限制
如果在调用该方法之后又调用了 enableAudio 或 disableAudio,则后调用的方法会生效。
参数
- muted
- 是否取消订阅所有远端用户的音频流:
true
: 取消订阅所有远端用户的音频流。false
:(默认)订阅所有远端用户的音频流。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
muteAllRemoteAudioStreamsEx
取消或恢复订阅所有远端用户的音频流。
public abstract int muteAllRemoteAudioStreamsEx(boolean muted, RtcConnection connection);
详情
成功调用该方法后,本地用户会取消或恢复订阅远端用户的音频流,包括在调用该方法后加入频道的用户的音频流。
- 该方法需要在加入频道后调用。
- 如果需要在加入频道前设置默认不订阅远端用户音频流,可以在调用 joinChannel [2/2] 加入频道时设置 autoSubscribeAudio 为
false
。
参数
- muted
- 是否取消订阅所有远端用户的音频流:
true
: 取消订阅所有远端用户的音频流。false
:(默认)订阅所有远端用户的音频流。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
muteAllRemoteVideoStreams
取消或恢复订阅所有远端用户的视频流。
public abstract int muteAllRemoteVideoStreams(boolean muted);
成功调用该方法后,本地用户会取消或恢复订阅所有远端用户的视频流,包括在调用该方法后加入频道的用户的视频流。
SDK 默认在加入频道时订阅所有远端用户的视频流,如果要修改此行为,可以在调用 joinChannel [2/2] 加入频道时设置 autoSubscribeVideo 为 false
,即可在加入频道时取消订阅所有用户的视频流。
调用时机
该方法需要在加入频道后调用。
调用限制
如果在调用该方法之后又调用了 enableVideo 或 disableVideo,则后调用的方法会生效。
参数
- muted
- 是否取消订阅所有远端用户的视频流。
true
: 取消订阅所有用户的视频流。false
:(默认)订阅所有用户的视频流。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
muteAllRemoteVideoStreamsEx
取消或恢复订阅所有远端用户的视频流。
public abstract int muteAllRemoteVideoStreamsEx(boolean muted, RtcConnection connection);
详情
成功调用该方法后,本地用户会取消或恢复订阅所有远端用户的视频流,包括在调用该方法后加入频道的用户的视频流。
参数
- muted
- 是否取消订阅所有远端用户的视频流。
true
: 取消订阅所有用户的视频流。false
:(默认)订阅所有用户的视频流。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
muteLocalAudioStream
取消或恢复发布本地音频流。
public abstract int muteLocalAudioStream(boolean muted);
该方法用于控制是否发布本地采集的音频流。如果不发布本地采集的音频流,也不会禁用音频采集设备,所以不影响音频的采集状态。
调用时机
加入频道前后均可调用。
调用限制
无。
相关回调
成功调用该方法后,本地会触发 onAudioPublishStateChanged 回调;远端会触发 onUserMuteAudio 回调和 onRemoteAudioStateChanged 回调。
参数
- muted
- 是否取消发布本地音频流。
true
: 取消发布。false
:(默认)发布。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
muteLocalAudioStreamEx
取消或恢复发布本地音频流。
public abstract int muteLocalAudioStreamEx(boolean muted, RtcConnection connection);
详情
成功调用该方法后,远端会触发 onUserMuteAudio 回调和 onRemoteAudioStateChanged 回调。
参数
- muted
- 是否取消发布本地音频流。
true
: 取消发布。false
:(默认)发布。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
muteLocalVideoStream
取消或恢复发布本地视频流。
public abstract int muteLocalVideoStream(boolean muted);
该方法用于控制是否发布本地采集的视频流。如果不发布本地采集的视频流,也不会禁用视频采集设备,所以不影响视频的采集状态。
相比于调用 enableLocalVideo(false
) 关闭本地视频流采集、从而取消发布本地视频流的方法,该方法响应速度更快。
调用时机
加入频道前后均可调用。
调用限制
无。
相关回调
成功调用该方法后,本地会触发 onVideoPublishStateChanged 回调;远端会触发 onUserMuteVideo 回调和 onRemoteVideoStateChanged 回调。
参数
- muted
- 是否取消发送本地视频流。
true
: 取消发送本地视频流。false
: (默认)发送本地视频流。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
muteLocalVideoStreamEx
取消或恢复发布本地视频流。
public abstract int muteLocalVideoStreamEx(boolean muted, RtcConnection connection);
详情
参数
- muted
- 是否取消发送本地视频流。
true
: 取消发送本地视频流。false
: (默认)发送本地视频流。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
muteRemoteAudioStream
取消或恢复订阅指定远端用户的音频流。
public abstract int muteRemoteAudioStream(int uid, boolean muted);
调用时机
该方法需要在加入频道后调用。
调用限制
无。
相关回调
成功调用该方法后,本地会触发 onAudioSubscribeStateChanged 回调。
参数
- uid
- 指定用户的用户 ID。
- muted
- 是否取消订阅指定远端用户的音频流。
true
: 取消订阅指定用户的音频流。false
:(默认)订阅指定用户的音频流。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
muteRemoteAudioStreamEx
停止/恢复接收指定的音频流。
public abstract int muteRemoteAudioStreamEx(int uid, boolean muted, RtcConnection connection);
详情
参数
- uid
- 指定用户的 ID。
- muted
是否停止接收指定音频流:
true
: 停止接收指定音频流。false
:(默认)继续接收指定音频流。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
muteRemoteVideoStream
取消或恢复订阅指定远端用户的视频流。
public abstract int muteRemoteVideoStream(int userId, boolean muted);
调用时机
该方法需要在加入频道后调用。
调用限制
无。
相关回调
成功调用该方法后,本地会触发 onVideoSubscribeStateChanged 回调。
参数
- userId
- 指定用户的用户 ID。
- muted
- 是否取消订阅指定远端用户的视频流。
true
: 取消订阅指定用户的视频流。false
: (默认)订阅指定用户的视频流。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
muteRemoteVideoStreamEx
停止/恢复接收指定的视频流。
public abstract int muteRemoteVideoStreamEx(int uid, boolean muted, RtcConnection connection);
详情
该方法停止/恢复接收某一个指定远端用户的视频流。在加入频道前或后都可以调用。该方法的设置在离开频道后失效。
参数
- uid
远端用户的 ID。
- muted
- 是否停止接收某个远端用户的视频:
true
: 停止接收。false
: (默认)恢复接收。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
setDualStreamMode [1/2]
在发送端设置双流模式。
public abstract int setDualStreamMode(Constants.SimulcastStreamMode mode);
详情
- 如果你想修改此行为,可以调用该方法并修改 mode 为 DISABLE_SIMULCAST_STREAM(始终不发送小流)或 ENABLE_SIMULCAST_STREAM(始终发送小流)。
- 如果你在进行修改后又想恢复该默认行为,可重新调用该方法,并将 mode 设置为 AUTO_SIMULCAST_STREAM。
- 调用该方法并设置 mode 为 DISABLE_SIMULCAST_STREAM 时,跟 enableDualStreamMode [1/2]
(false)
的效果相同。 - 调用该方法并设置 mode 为 ENABLE_SIMULCAST_STREAM 时,跟 enableDualStreamMode [1/2]
(true)
的效果相同。 - 两种方法均可在加入频道前后调用,若同时使用,则以后调用的方法中的设置为准。
参数
- mode
- 发送视频流的模式。详见 SIMULCAST_STREAM_MODE。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
setDualStreamMode [2/2]
在发送端设置双流模式并设置视频小流。
public abstract int setDualStreamMode(
Constants.SimulcastStreamMode mode, SimulcastStreamConfig streamConfig);
详情
- 如果你想修改此行为,可以调用该方法并修改 mode 为 DISABLE_SIMULCAST_STREAM(始终不发送小流)或 ENABLE_SIMULCAST_STREAM(始终发送小流)。
- 如果你在进行修改后又想恢复该默认行为,可重新调用该方法,并将 mode 设置为 AUTO_SIMULCAST_STREAM。
该方法跟 setDualStreamMode [1/2] 的区别在于,该方法还可以进行视频小流的配置,SDK 会根据 streamConfig 中的配置发送小流。
- 调用该方法并设置 mode 为 DISABLE_SIMULCAST_STREAM 时,跟调用 enableDualStreamMode [2/2] 并设置 enabled 为
false
的效果相同。 - 调用该方法并设置 mode 为 ENABLE_SIMULCAST_STREAM 时,跟调用 enableDualStreamMode [2/2] 并设置 enabled 为
true
的效果相同。 - 两种方法均可在加入频道前后调用,若同时使用,则以后调用的方法中的设置为准。
参数
- mode
- 发送视频流的模式。详见 SIMULCAST_STREAM_MODE。
- streamConfig
- 视频小流的配置。详见 SimulcastStreamConfig。信息当设置 mode 为 DISABLE_SIMULCAST_STREAM 时,再设置 streamConfig 不会生效。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。 详见错误码了解详情和解决建议。
setDualStreamModeEx
在发送端设置双流模式。
public abstract int setDualStreamModeEx(Constants.SimulcastStreamMode mode,
SimulcastStreamConfig streamConfig, RtcConnection connection);
详情
- 如果你想修改此行为,可以调用该方法并修改 mode 为 DISABLE_SIMULCAST_STREAM(始终不发送小流)或 ENABLE_SIMULCAST_STREAM(始终发送小流)。
- 如果你在进行修改后又想恢复该默认行为,可重新调用该方法,并将 mode 设置为 AUTO_SIMULCAST_STREAM。
- 调用该方法并设置 mode 为 DISABLE_SIMULCAST_STREAM 时,跟 enableDualStreamModeEx
(false)
的效果相同。 - 调用该方法并设置 mode 为 ENABLE_SIMULCAST_STREAM 时,跟 enableDualStreamModeEx
(true)
的效果相同。 - 两种方法均可在加入频道前后调用,若同时使用,则以后调用的方法中的设置为准。
参数
- mode
- 发送视频流的模式。详见 SIMULCAST_STREAM_MODE。
- streamConfig
- 视频小流的配置。详见 SimulcastStreamConfig。信息当设置 mode 为 DISABLE_SIMULCAST_STREAM 时,再设置 streamConfig 不会生效。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。 详见错误码了解详情和解决建议。
setRemoteDefaultVideoStreamType [1/2]
设置默认订阅的视频流类型。
public abstract int setRemoteDefaultVideoStreamType(int streamType);
- SDK 默认在发送端开启小流自适应模式 (AUTO_SIMULCAST_STREAM),即:发送端仅发送大流,仅主播身份的接收端可以调用该方法发起小流申请,发送端收到申请后开始自动发送小流,此时频道内所有用户均可调用该方法切换到小流订阅模式。
- 当发送端调用 setDualStreamMode [2/2] 并将 mode 设置为 DISABLE_SIMULCAST_STREAM(始终不发送小流),则调用该方法不生效。
- 当发送端调用 setDualStreamMode [2/2] 并将 mode 设置为 ENABLE_SIMULCAST_STREAM(始终发送小流),则主播或观众身份的接收端均可调用该方法切换到小流订阅模式。
在接收视频小流时,SDK 会根据视频窗口的大小动态调整对应视频流的大小,以节约带宽和计算资源。视频小流默认的宽高比和视频大流的宽高比一致。根据当前大流的宽高比,系统会自动分配小流的分辨率、帧率及码率。
调用时机
该方法只能在加入频道前调用。SDK 不支持你在加入频道后修改默认订阅的视频流类型。
调用限制
如果你既调用了该方法,也调用了 setRemoteVideoStreamType [1/2],则 SDK 以 setRemoteVideoStreamType [1/2] 中的设置为准。
参数
- streamType
- 默认订阅的视频流类型:
- VIDEO_STREAM_HIGH (0):视频大流,即高分辨率、高码率视频流。
- VIDEO_STREAM_LOW (1):视频小流,即低分辨率、低码率视频流。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setRemoteDefaultVideoStreamType [2/2]
设置默认订阅的视频流类型。
public abstract int setRemoteDefaultVideoStreamType(Constants.VideoStreamType streamType);
- SDK 默认在发送端开启小流自适应模式 (AUTO_SIMULCAST_STREAM),即:发送端仅发送大流,仅主播身份的接收端可以调用该方法发起小流申请,发送端收到申请后开始自动发送小流,此时频道内所有用户均可调用该方法切换到小流订阅模式。
- 当发送端调用 setDualStreamMode [2/2] 并将 mode 设置为 DISABLE_SIMULCAST_STREAM(始终不发送小流),则调用该方法不生效。
- 当发送端调用 setDualStreamMode [2/2] 并将 mode 设置为 ENABLE_SIMULCAST_STREAM(始终发送小流),则主播或观众身份的接收端均可调用该方法切换到小流订阅模式。
在接收视频小流时,SDK 会根据视频窗口的大小动态调整对应视频流的大小,以节约带宽和计算资源。视频小流默认的宽高比和视频大流的宽高比一致。根据当前大流的宽高比,系统会自动分配小流的分辨率、帧率及码率。
调用时机
该方法只能在加入频道前调用。SDK 不支持你在加入频道后修改默认订阅的视频流类型。
调用限制
如果你既调用了该方法,也调用了 setRemoteVideoStreamType [1/2],则 SDK 以 setRemoteVideoStreamType [1/2] 中的设置为准。
参数
- streamType
- 视频流类型: VideoStreamType。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setRemoteVideoStreamType [1/2]
设置订阅的视频流类型。
public abstract int setRemoteVideoStreamType(int uid, int streamType);
详情
- SDK 默认在发送端开启小流自适应模式 (AUTO_SIMULCAST_STREAM),即:发送端仅发送大流,仅主播身份的接收端可以调用该方法发起小流申请,发送端收到申请后开始自动发送小流,此时频道内所有用户均可调用该方法切换到小流订阅模式。
- 当发送端调用 setDualStreamMode [2/2] 并将 mode 设置为 DISABLE_SIMULCAST_STREAM(始终不发送小流),则调用该方法不生效。
- 当发送端调用 setDualStreamMode [2/2] 并将 mode 设置为 ENABLE_SIMULCAST_STREAM(始终发送小流),则主播或观众身份的接收端均可调用该方法切换到小流订阅模式。
在接收视频小流时,SDK 会根据视频窗口的大小动态调整对应视频流的大小,以节约带宽和计算资源。视频小流默认的宽高比和视频大流的宽高比一致。根据当前大流的宽高比,系统会自动分配小流的分辨率、帧率及码率。
- 该方法在加入频道前后都能调用。
- 如果既调用了该方法,也调用了 setRemoteDefaultVideoStreamType [1/2],则 SDK 以该方法中的设置为准。
参数
- uid
- 用户 ID。
- streamType
- 视频流类型:
- 0:视频大流。
- 1:视频小流。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setRemoteVideoStreamType [2/2]
设置订阅的视频流类型。
public abstract int setRemoteVideoStreamType(int uid, Constants.VideoStreamType streamType);
详情
- SDK 默认在发送端开启小流自适应模式 (AUTO_SIMULCAST_STREAM),即:发送端仅发送大流,仅主播身份的接收端可以调用该方法发起小流申请,发送端收到申请后开始自动发送小流,此时频道内所有用户均可调用该方法切换到小流订阅模式。
- 当发送端调用 setDualStreamMode [2/2] 并将 mode 设置为 DISABLE_SIMULCAST_STREAM(始终不发送小流),则调用该方法不生效。
- 当发送端调用 setDualStreamMode [2/2] 并将 mode 设置为 ENABLE_SIMULCAST_STREAM(始终发送小流),则主播或观众身份的接收端均可调用该方法切换到小流订阅模式。
在接收视频小流时,SDK 会根据视频窗口的大小动态调整对应视频流的大小,以节约带宽和计算资源。视频小流默认的宽高比和视频大流的宽高比一致。根据当前大流的宽高比,系统会自动分配小流的分辨率、帧率及码率。
- 该方法在加入频道前后都能调用。
- 如果既调用了该方法,也调用了 setRemoteDefaultVideoStreamType [1/2],则 SDK 以该方法中的设置为准。
参数
- uid
- 用户 ID。
- streamType
- 视频流类型: VideoStreamType。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setRemoteVideoStreamTypeEx [1/2]
设置订阅的视频流类型。
public abstract int setRemoteVideoStreamTypeEx(int uid, int streamType, RtcConnection connection);
详情
- SDK 默认在发送端开启小流自适应模式 (AUTO_SIMULCAST_STREAM),即:发送端仅发送大流,仅主播身份的接收端可以调用该方法发起小流申请,发送端收到申请后开始自动发送小流,此时频道内所有用户均可调用该方法切换到小流订阅模式。
- 当发送端调用 setDualStreamMode [2/2] 并将 mode 设置为 DISABLE_SIMULCAST_STREAM(始终不发送小流),则调用该方法不生效。
- 当发送端调用 setDualStreamMode [2/2] 并将 mode 设置为 ENABLE_SIMULCAST_STREAM(始终发送小流),则主播或观众身份的接收端均可调用该方法切换到小流订阅模式。
在接收视频小流时,SDK 会根据视频窗口的大小动态调整对应视频流的大小,以节约带宽和计算资源。视频小流默认的宽高比和视频大流的宽高比一致。根据当前大流的宽高比,系统会自动分配小流的分辨率、帧率及码率。
- 如果发送端已调用 setDualStreamModeEx 并将 mode 设置为 DISABLE_SIMULCAST_STREAM(始终不发送小流),则调用该方法不生效,你需要在发送端重新调用 setDualStreamModeEx 修改设置。
- 观众角色的接收端调用该方法不生效。
参数
- uid
- 用户 ID。
- streamType
- 视频流类型:
- 0:视频大流。
- 1:视频小流。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setRemoteVideoStreamTypeEx [2/2]
设置订阅的视频流类型。
public abstract int setRemoteVideoStreamTypeEx(
int uid, Constants.VideoStreamType streamType, RtcConnection connection);
详情
- SDK 默认在发送端开启小流自适应模式 (AUTO_SIMULCAST_STREAM),即:发送端仅发送大流,仅主播身份的接收端可以调用该方法发起小流申请,发送端收到申请后开始自动发送小流,此时频道内所有用户均可调用该方法切换到小流订阅模式。
- 当发送端调用 setDualStreamMode [2/2] 并将 mode 设置为 DISABLE_SIMULCAST_STREAM(始终不发送小流),则调用该方法不生效。
- 当发送端调用 setDualStreamMode [2/2] 并将 mode 设置为 ENABLE_SIMULCAST_STREAM(始终发送小流),则主播或观众身份的接收端均可调用该方法切换到小流订阅模式。
在接收视频小流时,SDK 会根据视频窗口的大小动态调整对应视频流的大小,以节约带宽和计算资源。视频小流默认的宽高比和视频大流的宽高比一致。根据当前大流的宽高比,系统会自动分配小流的分辨率、帧率及码率。
- 如果发送端已调用 setDualStreamModeEx 并将 mode 设置为 DISABLE_SIMULCAST_STREAM(始终不发送小流),则调用该方法不生效,你需要在发送端重新调用 setDualStreamModeEx 修改设置。
- 观众角色的接收端调用该方法不生效。
参数
- uid
- 用户 ID。
- streamType
- 视频流类型: VideoStreamType。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setRemoteVideoSubscriptionOptions
设置远端视频流的订阅选项。
public abstract int setRemoteVideoSubscriptionOptions(int uid, VideoSubscriptionOptions options);
详情
- 如果注册的是 IVideoFrameObserver 观测器,则默认订阅原始数据和编码后的数据。
- 如果注册的是 IVideoEncodedFrameObserver 观测器,则默认仅订阅编码后的数据。
- 如果注册了两种观测器,则默认跟随后注册的视频观测器。举例来说,如果后注册的是 IVideoFrameObserver 观测器,则默认订阅原始数据和编码后的数据。
uid
设置不同的订阅选项,可调用该方法设置。有关详细的实现步骤,详见自定义视频数据处理。参数
- uid
- 远端用户 ID。
- options
- 视频流的订阅设置,详见 VideoSubscriptionOptions。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setRemoteVideoSubscriptionOptionsEx
设置远端视频流的订阅选项。
public abstract int setRemoteVideoSubscriptionOptionsEx(
int uid, VideoSubscriptionOptions options, RtcConnection rtcConnection);
详情
当远端发送双流时,可调用此方法来设置远端视频流的订阅选项。
参数
- uid
- 远端用户 ID。
- options
- 视频流的订阅设置,详见 VideoSubscriptionOptions。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setSubscribeAudioAllowlist
设置音频订阅白名单。
public abstract int setSubscribeAudioAllowlist(int[] uidList);
详情
你可以调用该方法指定想要订阅的音频流。
- 该方法在加入频道前后均可调用。
- 音频订阅白名单不受 muteRemoteAudioStream、muteAllRemoteAudioStreams 以及 ChannelMediaOptions 中的 autoSubscribeAudio 的影响。
- 设置订阅白名单后,如果离开当前频道后再重新加入频道,白名单依然生效。
- 如果某个用户同时在音频订阅黑名单和白名单中,仅订阅黑名单生效。
参数
- uidList
音频订阅白名单的用户 ID 列表。
如果你想指定订阅某一发流用户的音频流,将该用户的 ID 加入此列表中。如果你想要将某一用户从订阅白名单中移除,需要重新调用 setSubscribeAudioAllowlist 方法更新音频订阅白名单的用户 ID 列表,使其不包含你想移除的用户的 uid。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setSubscribeAudioAllowlistEx
设置音频订阅白名单。
public abstract int setSubscribeAudioAllowlistEx(int[] uidList, RtcConnection connection);
详情
你可以调用该方法指定想要订阅的音频流。
- 该方法在加入频道前后均可调用。
- 音频订阅白名单不受 muteRemoteAudioStream、muteAllRemoteAudioStreams 以及 ChannelMediaOptions 中的 autoSubscribeAudio 的影响。
- 设置订阅白名单后,如果离开当前频道后再重新加入频道,白名单依然生效。
- 如果某个用户同时在音频订阅黑名单和白名单中,仅订阅黑名单生效。
参数
- uidList
音频订阅白名单的用户 ID 列表。
如果你想指定订阅某一发流用户的音频流,将该用户的 ID 加入此列表中。如果你想要将某一用户从订阅白名单中移除,需要重新调用 setSubscribeAudioAllowlist 方法更新音频订阅白名单的用户 ID 列表,使其不包含你想移除的用户的 uid。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setSubscribeAudioBlocklist
设置音频订阅黑名单。
public abstract int setSubscribeAudioBlocklist(int[] uidList);
详情
你可以调用该方法指定不订阅的音频流。
- 该方法在加入频道前后均可调用。
- 音频订阅黑名单不受 muteRemoteAudioStream、muteAllRemoteAudioStreams 以及 ChannelMediaOptions 中的 autoSubscribeAudio 影响。
- 设置订阅黑名单后,如果离开当前频道后再重新加入频道,黑名单依然生效。
- 如果某个用户同时在音频订阅黑名单和白名单中,仅订阅黑名单生效。
参数
- uidList
订阅黑名单的用户 ID 列表。
如果你想指定不订阅某一发流用户的音频流,将该用户的 ID 加入此列表中。如果你想要将某一用户从订阅黑名单中移除,需要重新调用 setSubscribeAudioBlocklist 方法更新订阅黑名单的用户 ID 列表,使其不包含你想移除的用户的 uid。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setSubscribeAudioBlocklistEx
设置音频订阅黑名单。
public abstract int setSubscribeAudioBlocklistEx(int[] uidList, RtcConnection connection);
详情
你可以调用该方法指定不订阅的音频流。
- 该方法在加入频道前后均可调用。
- 音频订阅黑名单不受 muteRemoteAudioStream、muteAllRemoteAudioStreams 以及 ChannelMediaOptions 中的 autoSubscribeAudio 影响。
- 设置订阅黑名单后,如果离开当前频道后再重新加入频道,黑名单依然生效。
- 如果某个用户同时在音频订阅黑名单和白名单中,仅订阅黑名单生效。
参数
- uidList
订阅黑名单的用户 ID 列表。
如果你想指定不订阅某一发流用户的音频流,将该用户的 ID 加入此列表中。如果你想要将某一用户从订阅黑名单中移除,需要重新调用 setSubscribeAudioBlocklist 方法更新订阅黑名单的用户 ID 列表,使其不包含你想移除的用户的 uid。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setSubscribeVideoAllowlist
设置视频订阅白名单。
public abstract int setSubscribeVideoAllowlist(int[] uidList);
详情
你可以调用该方法指定想要订阅的视频流。
- 该方法在加入频道前后均可调用。
- 视频订阅白名单不受 muteRemoteVideoStream、muteAllRemoteVideoStreams 以及 ChannelMediaOptions 中的 autoSubscribeVideo 的影响。
- 设置订阅白名单后,如果离开当前频道后再重新加入频道,白名单依然生效。
- 如果某个用户同时在音频订阅黑名单和白名单中,仅订阅黑名单生效。
参数
- uidList
视频订阅白名单的用户 ID 列表。
如果你想指定仅订阅某一发流用户的视频流,将该用户的 ID 加入此列表中。如果你想要将某一用户从订阅白名单中移除,需要重新调用 setSubscribeVideoAllowlist 方法更新音频订阅白名单的用户 ID 列表,使其不包含你想移除的用户的 uid。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setSubscribeVideoAllowlistEx
设置视频订阅白名单。
public abstract int setSubscribeVideoAllowlistEx(int[] uidList, RtcConnection connection);
详情
你可以调用该方法指定想要订阅的视频流。
- 该方法在加入频道前后均可调用。
- 视频订阅白名单不受 muteRemoteVideoStream、muteAllRemoteVideoStreams 以及 ChannelMediaOptions 中的 autoSubscribeVideo 的影响。
- 设置订阅白名单后,如果离开当前频道后再重新加入频道,白名单依然生效。
- 如果某个用户同时在音频订阅黑名单和白名单中,仅订阅黑名单生效。
参数
- uidList
视频订阅白名单的用户 ID 列表。
如果你想指定仅订阅某一发流用户的视频流,将该用户的 ID 加入此列表中。如果你想要将某一用户从订阅白名单中移除,需要重新调用 setSubscribeVideoAllowlist 方法更新音频订阅白名单的用户 ID 列表,使其不包含你想移除的用户的 uid。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setSubscribeVideoBlocklist
设置视频订阅黑名单。
public abstract int setSubscribeVideoBlocklist(int[] uidList);
详情
你可以调用该方法指定不订阅的视频流。
- 该方法在加入频道前后均可调用。
- 视频订阅黑名单不受 muteRemoteVideoStream、muteAllRemoteVideoStreams 以及 ChannelMediaOptions 中的 autoSubscribeVideo 的影响。
- 设置订阅黑名单后,如果离开当前频道后再重新加入频道,黑名单依然生效。
- 如果某个用户同时在音频订阅黑名单和白名单中,仅订阅黑名单生效。
参数
- uidList
视频订阅黑名单的用户 ID 列表。
如果你想指定不订阅某一发流用户的视频流,将该用户的 ID 加入此列表中。如果你想要将某一用户从订阅黑名单中移除,需要重新调用 setSubscribeVideoBlocklist 方法更新订阅黑名单的用户 ID 列表,使其不包含你想移除的用户的 uid。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
setSubscribeVideoBlocklistEx
设置视频订阅黑名单。
public abstract int setSubscribeVideoBlocklistEx(int[] uidList, RtcConnection connection);
详情
你可以调用该方法指定不订阅的视频流。
- 该方法在加入频道前后均可调用。
- 视频订阅黑名单不受 muteRemoteVideoStream、muteAllRemoteVideoStreams 以及 ChannelMediaOptions 中的 autoSubscribeVideo 的影响。
- 设置订阅黑名单后,如果离开当前频道后再重新加入频道,黑名单依然生效。
- 如果某个用户同时在音频订阅黑名单和白名单中,仅订阅黑名单生效。
参数
- uidList
视频订阅黑名单的用户 ID 列表。
如果你想指定不订阅某一发流用户的视频流,将该用户的 ID 加入此列表中。如果你想要将某一用户从订阅黑名单中移除,需要重新调用 setSubscribeVideoBlocklist 方法更新订阅黑名单的用户 ID 列表,使其不包含你想移除的用户的 uid。
- connection
- Connection 信息。详见 RtcConnection。
返回值
- 0: 方法调用成功。
- < 0: 方法调用失败。详见错误码了解详情和解决建议。
onAudioPublishStateChanged
音频发布状态改变回调。
public void onAudioPublishStateChanged(String channel, STREAM_PUBLISH_STATE oldState,
STREAM_PUBLISH_STATE newState, int elapseSinceLastState) {}
参数
- channel
- 频道名。
- oldState
- 之前的发布状态,详见 STREAM_PUBLISH_STATE。
- newState
- 当前的发布状态,详见 STREAM_PUBLISH_STATE。
- elapseSinceLastState
- 两次状态变化时间间隔(毫秒)。
onAudioSubscribeStateChanged
音频订阅状态发生改变回调。
public void onAudioSubscribeStateChanged(
String channel, int uid, int oldState, int newState, int elapseSinceLastState) {}
参数
- channel
- 频道名。
- uid
- 远端用户的 ID。
- oldState
- 之前的订阅状态。
- SUB_STATE_IDLE (0): 加入频道后的初始订阅状态。
- SUB_STATE_NO_SUBSCRIBED (1): 订阅失败。可能是因为:
- 远端用户:
- 调用 muteLocalAudioStream(
true
) 停止发送本地音频流。 - 调用 disableAudio 关闭本地音频模块。
- 调用 enableLocalAudio(
false
) 关闭本地音频采集。 - 用户角色为观众。
- 调用 muteLocalAudioStream(
- 本地用户调用以下方法停止接收远端音频流:
- 调用 joinChannel [2/2] 或 updateChannelMediaOptions 时设置 autoSubscribeAudio 为
false
,不自动订阅任何音频流。 - 调用 muteRemoteAudioStream 或 muteAllRemoteAudioStreams 时设置 muted 为
true
,停止接收远端音频流。
- 调用 joinChannel [2/2] 或 updateChannelMediaOptions 时设置 autoSubscribeAudio 为
- 远端用户:
- SUB_STATE_SUBSCRIBING (2): 正在订阅。
- SUB_STATE_SUBSCRIBED (3): 收到了远端流,订阅成功。
- newState
- 当前的订阅状态。
- SUB_STATE_IDLE (0): 加入频道后的初始订阅状态。
- SUB_STATE_NO_SUBSCRIBED (1): 订阅失败。可能是因为:
- 远端用户:
- 调用 muteLocalAudioStream(
true
) 停止发送本地音频流。 - 调用 disableAudio 关闭本地音频模块。
- 调用 enableLocalAudio(
false
) 关闭本地音频采集。 - 用户角色为观众。
- 调用 muteLocalAudioStream(
- 本地用户调用以下方法停止接收远端音频流:
- 调用 joinChannel [2/2] 或 updateChannelMediaOptions 时设置 autoSubscribeAudio 为
false
,不自动订阅任何音频流。 - 调用 muteRemoteAudioStream 或 muteAllRemoteAudioStreams 时设置 muted 为
true
,停止接收远端音频流。
- 调用 joinChannel [2/2] 或 updateChannelMediaOptions 时设置 autoSubscribeAudio 为
- 远端用户:
- SUB_STATE_SUBSCRIBING (2): 正在订阅。
- SUB_STATE_SUBSCRIBED (3): 收到了远端流,订阅成功。
- elapseSinceLastState
- 两次状态变化时间间隔(毫秒)。
onVideoSubscribeStateChanged
视频订阅状态发生改变回调。
public void onVideoSubscribeStateChanged(
String channel, int uid, int oldState, int newState, int elapseSinceLastState) {}
参数
- channel
- 频道名。
- uid
- 远端用户的 ID。
- oldState
- 之前的订阅状态。
- SUB_STATE_IDLE (0): 加入频道后的初始订阅状态。
- SUB_STATE_NO_SUBSCRIBED (1): 订阅失败。可能是因为:
- 远端用户:
- 调用 muteLocalVideoStream(
true
) 停止发送本地视频流。 - 调用 disableVideo 关闭本地视频模块。
- 调用 enableLocalVideo(
false
) 关闭本地视频采集。 - 用户角色为观众。
- 调用 muteLocalVideoStream(
- 本地用户调用以下方法停止接收远端视频流:
- 调用 joinChannel [2/2] 或 updateChannelMediaOptions 时设置 autoSubscribeVideo 为
false
,不自动订阅任何视频流。 - 调用 muteRemoteVideoStream 或 muteAllRemoteVideoStreams 时设置 muted 为
true
,停止接收远端视频流。
- 调用 joinChannel [2/2] 或 updateChannelMediaOptions 时设置 autoSubscribeVideo 为
- 远端用户:
- SUB_STATE_SUBSCRIBING (2): 正在订阅。
- SUB_STATE_SUBSCRIBED (3): 收到了远端流,订阅成功。
- newState
- 当前的订阅状态。
- SUB_STATE_IDLE (0): 加入频道后的初始订阅状态。
- SUB_STATE_NO_SUBSCRIBED (1): 订阅失败。可能是因为:
- 远端用户:
- 调用 muteLocalVideoStream(
true
) 停止发送本地视频流。 - 调用 disableVideo 关闭本地视频模块。
- 调用 enableLocalVideo(
false
) 关闭本地视频采集。 - 用户角色为观众。
- 调用 muteLocalVideoStream(
- 本地用户调用以下方法停止接收远端视频流:
- 调用 joinChannel [2/2] 或 updateChannelMediaOptions 时设置 autoSubscribeVideo 为
false
,不自动订阅任何视频流。 - 调用 muteRemoteVideoStream 或 muteAllRemoteVideoStreams 时设置 muted 为
true
,停止接收远端视频流。
- 调用 joinChannel [2/2] 或 updateChannelMediaOptions 时设置 autoSubscribeVideo 为
- 远端用户:
- SUB_STATE_SUBSCRIBING (2): 正在订阅。
- SUB_STATE_SUBSCRIBED (3): 收到了远端流,订阅成功。
- elapseSinceLastState
- 两次状态变化时间间隔(毫秒)。