sendUserBinaryMessageOutsideRoom method

Future<int?> sendUserBinaryMessageOutsideRoom({
  1. required string uid,
  2. required ArrayBuffer message,
  3. required MessageConfig config,
})

@detail api @author hanchenchen.c @brief 给房间外指定的用户发送二进制消息(P2P) @param uid
消息接收用户的 ID @param buffer
发送的二进制消息内容
消息不超过 64KB。 @param config 消息类型,参看 MessageConfig{@link #MessageConfig}。 @return - >0:发送成功,返回这次发送消息的编号,从 1 开始递增。 - -1:发送失败。消息为空。 @note - 在发送房间外二进制消息前,必须先调用 login{@link #RTCEngine#login} 完成登录。 - 用户调用本接口发送二进制消息后,会收到一次 onUserMessageSendResultOutsideRoom{@link #IRTCEngineEventHandler#onUserMessageSendResultOutsideRoom} 回调,通知消息是否发送成功; - 若二进制消息发送成功,则 uid 所指定的用户会通过 onUserBinaryMessageReceivedOutsideRoom{@link #IRTCEngineEventHandler#onUserBinaryMessageReceivedOutsideRoom} 回调收到该条消息。

Implementation

Future<int?> sendUserBinaryMessageOutsideRoom(
    {required string uid,
    required ArrayBuffer message,
    required MessageConfig config}) async {
  $a() => ($instance as $p_a.RTCEngine).sendUserBinaryMessageOutsideRoom(
      uid, message, t_MessageConfig.code_to_android(config));
  $i() => ($instance as $p_i.ByteRTCEngine).sendUserBinaryMessageOutsideRoom(
      uid, message, t_MessageConfig.code_to_ios(config));

  if (Platform.isAndroid) {
    return $a();
  } else if (Platform.isIOS) {
    return $i();
  } else {
    throw UnsupportedError(
        'Not Support Platform ${Platform.operatingSystem}');
  }
}