Options
All
  • Public
  • Public/Protected
  • All
Menu

Class RCLivingRoom

直播房间

Hierarchy

Index

Constructors

  • new RCLivingRoom(context: RTCContext, runtime: IRuntime, roomId: string, service: default, initOptions: IRCRTCInitOptions, _livingType: RCLivingType, isUpgrade?: boolean, isMainRoom?: boolean, useMutilPeerC?: boolean, _clientSessionId?: string): RCLivingRoom
  • 一个构造函数。

    Parameters

    • context: RTCContext

      RTC上下文,

    • runtime: IRuntime

      运行时

    • roomId: string

      房间号

    • service: default

      RCMediaService

    • initOptions: IRCRTCInitOptions

      IRCRTCInitOptions

    • _livingType: RCLivingType

      RCLivingType.LIVE_ROOM,

    • Optional isUpgrade: boolean
    • Optional isMainRoom: boolean
    • Optional useMutilPeerC: boolean
    • Optional _clientSessionId: string

    Returns RCLivingRoom

Properties

_mcuConfigBuilder: RCMCUConfigBuilder
_roomId: string

Accessors

  • 获取当前已经订阅的全量资源 returns subscribedTracks ISubscribeAttr[]

    Returns ISubscribeAttr[]

Methods

  • __destroy(quitRoom: boolean): Promise<void>
  • 退出并销毁当前房间实例,退出后该房间的所有方法将不可用

    Parameters

    • quitRoom: boolean

    Returns Promise<void>

  • __getCDNEnable(): boolean
  • 返回 CDN 是否可用

    Returns boolean

    boolean

  • __getCDNPushMode(): undefined | RCInnerCDNPushMode
  • 返回 CDN 推送模式: 自动 or 手动

    Returns undefined | RCInnerCDNPushMode

  • __getPC(): default[]
  • 获取 _pc 实例

    Returns default[]

  • __innerInit(mode: RTCMode, joinType?: RTCJoinType, livingType?: RCLivingType, innerUserDatas?: IRTCUserData, outerUserDatas?: IRTCUserData, traceId?: string): Promise<{ code: RCRTCCode | ErrorCode; data?: IJoinRTCRoomData }>
  • override

    Parameters

    • mode: RTCMode
    • Optional joinType: RTCJoinType
    • Optional livingType: RCLivingType
    • Optional innerUserDatas: IRTCUserData
    • Optional outerUserDatas: IRTCUserData
    • Optional traceId: string

    Returns Promise<{ code: RCRTCCode | ErrorCode; data?: IJoinRTCRoomData }>

  • __innerInitByIdentityChange(traceId: string): Promise<ErrorCode>
  • Parameters

    • traceId: string

    Returns Promise<ErrorCode>

  • __onReconnected(livingType?: RCLivingType): Promise<void | { data: undefined | IJoinRTCRoomData }>
  • 断线重连后尝试补发断线过程中的通知信息

    Parameters

    Returns Promise<void | { data: undefined | IJoinRTCRoomData }>

  • __parseInnerMessage(message: IReceivedMessage, traceId: string): boolean
  • 它将订阅任务添加到队列中。

    Parameters

    Returns void

    一个用代码和失败列表解析为对象的承诺。

  • 它将取消订阅任务添加到队列中。

    Parameters

    Returns void

    一个用代码和失败列表解析为对象的承诺。

  • clear(): void
  • 无差别清空所有事件监听器

    Returns void

  • deleteRoomAttributes(keys: string[], message?: { content: string; name: string }, isInner?: boolean): Promise<{ code: RCRTCCode }>
  • 删除房间属性

    Parameters

    • keys: string[]

      待删除的属性名数组

    • Optional message: { content: string; name: string }

      是否在删除属性的时候携带消息内容,传空则不往房间中发送消息

      • content: string
      • name: string
    • isInner: boolean = false

      RTC 业务内部使用参数,用户忽略

    Returns Promise<{ code: RCRTCCode }>

  • emit(eventType: string, ...attrs: any[]): void
  • 事件派发

    Parameters

    • eventType: string
    • Rest ...attrs: any[]

    Returns void

  • enableInnerCDN(enable: boolean): Promise<{ code: RCRTCCode }>
  • 开启/停用推 CDN

    Parameters

    • enable: boolean

    Returns Promise<{ code: RCRTCCode }>

  • getClientSessionId(): string
  • getCrtUserId(): string
  • Returns RCLivingType

  • getRemoteUserIds(): string[]
  • 获取远程用户列表,不包含当前用户

    Returns string[]

  • getRoomAttributes(keys?: string[], isInner?: boolean): Promise<{ code: RCRTCCode; data?: KVString }>
  • 获取房间属性

    Parameters

    • keys: string[] = []

      要查询的属性名数组,当数组长度为空时,取所有已设置的 kv 值

    • isInner: boolean = false

      RTC 业务内部使用参数,用户忽略

    Returns Promise<{ code: RCRTCCode; data?: KVString }>

  • getRoomId(): string
  • 获取房间 Id

    Returns string

  • getRoomPKHandler(): { code: RCRTCCode; roomPKHandler?: RCLivingPKHandler }
  • 获取 PK 业务处理器

    since

    version 5.3.0

    Returns { code: RCRTCCode; roomPKHandler?: RCLivingPKHandler }

    • code: RCRTCCode
    • Optional roomPKHandler?: RCLivingPKHandler
  • getSessionId(): string
  • 获取房间当前会话 Id,当房间内已无成员时房间会回收,重新加入时 sessionId 将更新

    Returns string

  • isDestroyed(): boolean
  • 查询房间是否已销毁

    Returns boolean

  • isMainRoom(): undefined | boolean
  • 是否是主房间

    Returns undefined | boolean

  • off(eventType: string, listener: IEventListener, target?: any): void
  • 移除事件监听器

    Parameters

    • eventType: string
    • listener: IEventListener
    • Optional target: any

    Returns void

  • on(eventType: string, listener: IEventListener, target?: any): void
  • 添加事件监听器

    Parameters

    • eventType: string
    • listener: IEventListener
    • Optional target: any

    Returns void

  • onAudioLevelChange(handler: null | IAudioLevelChangeHandler, gap?: number): void
  • 音量上报

    Parameters

    • handler: null | IAudioLevelChangeHandler

      业务端传入的音量上报事件

    • Optional gap: number

      上报时间间隔

    Returns void

  • once(eventType: string, listener: IEventListener, target?: any): void
  • Parameters

    • eventType: string
    • listener: IEventListener
    • Optional target: any

    Returns void

  • 注册事件监听器,多次注册会导致后者覆盖前者,可以通过使用 registerRoomEventListener(null) 取消注册

    Parameters

    Returns void

  • removeAll(eventType: string): void
  • 清空所有指定类型的事件监听器

    Parameters

    • eventType: string

    Returns void

  • sendMessage(name: string, content: any): Promise<{ code: RCRTCCode }>
  • 向房间内发消息

    Parameters

    • name: string

      消息名称

    • content: any

      消息内容

    Returns Promise<{ code: RCRTCCode }>

  • setBitrate(max: number, min: number, start?: number): void
  • 设置房间上行资源的总码率配置

    deprecated

    use RCLocalTrack.setBitrate instead of setBitrate

    description
    • 自 v5.1.0 版本开始,推荐使用 RCLocalTrack.setBitrate 对不同流分别指定码率。
    • 该方法仅在 SDP plan-b 协议下(Chrome 92 与 Safari 11 之前的版本)有效。

    Parameters

    • max: number

      音视频发送码率上限,不可小于 200 且不可小于 min

    • min: number

      音视频发送码率下限,默认值为 1,且不可小于 1,不可大于 max

    • Optional start: number

      起始码率,默认为码率上限的 70%

    Returns void

  • setRoomAttribute(key: string, value: string, message?: { content: string; name: string }, isInner?: boolean): Promise<{ code: RCRTCCode }>
  • 设置房间属性

    Parameters

    • key: string

      属性名

    • value: string

      属性值

    • Optional message: { content: string; name: string }

      是否在设置属性的时候携带消息内容,传空则不往房间中发送消息

      • content: string
      • name: string
    • isInner: boolean = false

      RTC 业务内部使用参数,用户忽略

    Returns Promise<{ code: RCRTCCode }>

Generated using TypeDoc