rtcRoom$onAudioSubscribeStateChanged$info$state$reason method

FutureOr<void> rtcRoom$onAudioSubscribeStateChanged$info$state$reason(
  1. dynamic rtcRoom,
  2. dynamic streamId,
  3. dynamic info,
  4. dynamic state,
  5. dynamic reason,
)
override

@detail callback brief Callback on the subscribing state change of the audio stream. @param rtcRoom The ByteRTCRoom instance. @param streamId Stream ID. @param info Stream information. @param state Room state code. See ByteRTCSubscribeState{@link #ByteRTCSubscribeState} for more. @param reason See ByteRTCSubscribeStateChangeReason{@link #ByteRTCSubscribeStateChangeReason} for more.

Implementation

FutureOr<void> rtcRoom$onAudioSubscribeStateChanged$info$state$reason(
    dynamic rtcRoom,
    dynamic streamId,
    dynamic info,
    dynamic state,
    dynamic reason) async {
  if ($instance == null || $instance is! IRTCRoomEventHandler) {
    return;
  }
  return ($instance as IRTCRoomEventHandler)
      .onAudioSubscribeStateChanged
      ?.call(
          streamId.toString(),
          t_SubscribeState.ios_to_code($p_i.ByteRTCSubscribeState.values
              .firstWhere((t) => t.$value == state || t.name == state)),
          t_SubscribeStateChangeReason.ios_to_code($p_i
              .ByteRTCSubscribeStateChangeReason.values
              .firstWhere((t) => t.$value == reason || t.name == reason)));
}