Class V2TIMMessageManager

腾讯云通信服务 IMSDK

消息高级接口,里面包含了所有高级消息的创建、收发逻辑

  • 1.1 添加高级消息的事件监听器

    Parameters

    Returns void

  • 1.2 移除高级消息监听器

    Parameters

    Returns void

  • 2.2 创建文本消息,并且可以附带 @ 提醒功能(该接口已弃用,推荐使用 CreateAtSignedGroupMessage 接口)

    提醒消息仅适用于在群组中发送的消息

    Parameters

    • text: string
    • atUserList: string[]

      需要 @ 的用户列表,如果需要 @ALL,请传入 kImSDK_MesssageAtALL 常量字符串。 举个例子,假设该条文本消息希望@提醒 denny 和 lucy 两个用户,同时又希望 @所有人,atUserList 传 {"denny","lucy",kImSDK_MesssageAtALL}

    Returns V2TIMMessage

    Note

    atUserList 使用注意事项

    • 默认情况下,最多支持 @ 30个用户,超过限制后,消息会发送失败。
    • atUserList 的总数不能超过默认最大数,包括 @ALL。
    • 直播群(AVChatRoom)不支持发送 @ 消息。
  • 2.4 创建自定义消息

    Parameters

    • data: ArrayBuffer
    • Optional option: {
          description?: string;
          extension?: string;
      }
      • Optional description?: string
      • Optional extension?: string

    Returns V2TIMMessage

  • 2.5 创建图片消息(图片最大支持 28 MB)

    Parameters

    • imagePath: string

    Returns V2TIMMessage

  • 2.6 创建语音消息(语音最大支持 28 MB)

    Parameters

    • soundPath: string
    • duration: number

      语音时长,单位 s

    Returns V2TIMMessage

  • 2.7 创建视频消息(视频最大支持 100 MB)

    Parameters

    • videoFilePath: string
    • type: string

      视频类型,如 mp4 mov 等

    • duration: number

      视频时长,单位 s

    • snapshotPath: string

      视频封面图片路径

    Returns V2TIMMessage

  • 2.8 创建文件消息(文件最大支持 100 MB)

    Parameters

    • filePath: string
    • fileName: string

    Returns V2TIMMessage

  • 2.9 创建地理位置消息

    Parameters

    • desc: string
    • longitude: number
    • latitude: number

    Returns V2TIMMessage

  • 2.10 创建表情消息

    SDK 并不提供表情包,如果开发者有表情包,可使用 index 存储表情在表情包中的索引, 或者直接使用 data 存储表情二进制信息以及字符串 key,都由用户自定义,SDK 内部只做透传。

    Parameters

    • index: number

      表情索引

    • data: ArrayBuffer

      自定义数据

    Returns V2TIMMessage

  • 2.11 创建合并消息(5.2.210 及以上版本支持)

    我们在收到一条合并消息的时候,通常会在聊天界面这样显示:

    |vinson 和 lynx 的聊天记录 | -- title (标题)

    |vinson:新版本 SDK 计划什么时候上线呢? | -- abstract1 (摘要信息1)

    |lynx:计划下周一,具体时间要看下这两天的系统测试情况..| -- abstract2 (摘要信息2)

    |vinson:好的. | -- abstract3 (摘要信息3)

    聊天界面通常只会展示合并消息的标题和摘要信息,完整的转发消息列表,需要用户主动点击转发消息 UI 后再获取。

    多条被转发的消息可以被创建成一条合并消息 V2TIMMessage,然后调用 SendMessage 接口发送,实现步骤如下:

    1. 调用 CreateMergerMessage 创建一条合并消息 V2TIMMessage。

    2. 调用 SendMessage 发送转发消息 V2TIMMessage。

    收到合并消息解析步骤:

    1. 通过 V2TIMMessage 获取 mergerElem。

    2. 通过 mergerElem 获取 title 和 abstractList UI 展示。

    3. 当用户点击摘要信息 UI 的时候,调用 DownloadMessageList 接口获取转发消息列表。

    Parameters

    • messageList: V2TIMMessage[]

      消息列表(最大支持 300 条,消息对象必须是 V2TIM_MSG_STATUS_SEND_SUCC 状态,消息类型不能为 V2TIMGroupTipsElem)

    • title: string

      合并消息的来源,比如 "vinson 和 lynx 的聊天记录"、"xxx 群聊的聊天记录"。

    • abstractList: string[]

      合并消息的摘要列表(最大支持 5 条摘要,每条摘要的最大长度不超过 100 个字符),不同的消息类型可以设置不同的摘要信息,比如: 文本消息可以设置为:sender:text,图片消息可以设置为:sender:[图片],文件消息可以设置为:sender:[文件]。

    • compatibleText: string

      合并消息兼容文本,低版本 SDK 如果不支持合并消息,默认会收到一条文本消息,文本消息的内容为 compatibleText, 该参数不能为空字符串。

    Returns undefined | V2TIMMessage

  • 2.12 创建转发消息(5.2.210 及以上版本支持)

    如果需要转发一条消息,不能直接调用 SendMessage 接口发送原消息,需要先 CreateForwardMessage 创建一条转发消息再发送。

    Parameters

    • message: V2TIMMessage

      待转发的消息对象,消息状态必须为 V2TIM_MSG_STATUS_SEND_SUCC,消息类型不能为 V2TIMGroupTipsElem。

    Returns undefined | V2TIMMessage

    转发消息对象,elem 内容和原消息完全一致。

  • 2.13 创建定向群消息(6.0 及以上版本支持)

    如果您需要在群内给指定群成员列表发消息,可以创建一条定向群消息,定向群消息只有指定群成员才能收到。

    Parameters

    • message: V2TIMMessage

      原始消息对象

    • receiverList: string[]

      消息接收者列表

    Returns undefined | V2TIMMessage

    定向群消息对象

    Note

    请注意:

    • 原始消息对象不支持群 @ 消息。
    • 消息接收者列表最大支持 50 个。
    • 社群(Community)和直播群(AVChatRoom)不支持发送定向群消息。
    • 定向群消息默认不计入群会话的未读计数。
  • 2.14 创建带 @ 标记的群消息(7.0 及以上版本支持)

    如果您需要发送的群消息附带 @ 提醒功能,可以创建一条带 @ 标记的群消息。

    Parameters

    • message: V2TIMMessage

      原始消息对象

    • atUserList: string[]

      需要 @ 的用户列表,如果需要 @ALL,请传入 kImSDK_MesssageAtALL 常量字符串。 举个例子,假设该条消息希望@提醒 denny 和 lucy 两个用户,同时又希望@所有人,atUserList 传 @[@"denny",@"lucy",kImSDK_MesssageAtALL]

    Returns undefined | V2TIMMessage

    群 @ 消息对象

    Note

    atUserList 使用注意事项

    • 默认情况下,最多支持 @ 30个用户,超过限制后,消息会发送失败。
    • atUserList 的总数不能超过默认最大数,包括 @ALL。
    • 直播群(AVChatRoom)不支持发送 @ 消息。
  • 3.1 发送高级消息(高级版本:可以指定优先级,推送信息等特性)

    Parameters

    Returns {
        msgID: string;
        promise: Promise<V2TIMMessage>;
    }

    消息唯一标识

    Note

    • 设置 offlinePushInfo 字段,需要先在 V2TIMOfflinePushManager 开启推送,推送开启后,除了自定义消息,其他消息默认都会推送。
    • 如果自定义消息也需要推送,请设置 offlinePushInfo 的 desc 字段,设置成功后,推送的时候会默认展示 desc 信息。
    • AVChatRoom 群聊不支持 onlineUserOnly 字段,如果是 AVChatRoom 请将该字段设置为 false。
    • 如果设置 onlineUserOnly 为 true 时,该消息为在线消息且不会被计入未读计数。
  • 4.1 设置针对某个用户的 C2C 消息接收选项(支持批量设置)

    5.3.425 及以上版本支持

    Parameters

    • userIDList: string[]
    • opt: V2TIMReceiveMessageOpt

      三种类型的消息接收选项: V2TIMMessage.V2TIM_RECEIVE_MESSAGE:在线正常接收消息,离线时会有厂商的离线推送通知 V2TIMMessage.V2TIM_NOT_RECEIVE_MESSAGE:不会接收到消息 V2TIMMessage.V2TIM_RECEIVE_NOT_NOTIFY_MESSAGE:在线正常接收消息,离线不会有推送通知

    Returns Promise<void>

    Note

    请注意:

    • 该接口支持批量设置,您可以通过参数 userIDList 设置一批用户,但一次最大允许设置 30 个用户。
    • 该接口调用频率被限制为1秒内最多调用5次。
  • 4.3 设置群消息的接收选项

    Parameters

    • groupID: string
    • opt: V2TIMReceiveMessageOpt

      三种类型的消息接收选项: V2TIMMessage.V2TIM_RECEIVE_MESSAGE:在线正常接收消息,离线时会有厂商的离线推送通知 V2TIMMessage.V2TIM_NOT_RECEIVE_MESSAGE:不会接收到群消息 V2TIMMessage.V2TIM_RECEIVE_NOT_NOTIFY_MESSAGE:在线正常接收消息,离线不会有推送通知 V2TIMMessage.V2TIM_RECEIVE_NOT_NOTIFY_MESSAGE_EXCEPT_AT:在线正常接收消息,离线只推送 @ 消息

    Returns Promise<void>

  • 4.4 设置全局消息接收选项,从 7.4 版本开始支持。

    Parameters

    • opt: V2TIMReceiveMessageOpt

      全局消息接收选项,支持两种取值: V2TIMReceiveMessageOpt.V2TIM_RECEIVE_MESSAGE:在线正常接收消息,离线时会有厂商的离线推送通知,默认为该选项 V2TIMReceiveMessageOpt.V2TIM_RECEIVE_NOT_NOTIFY_MESSAGE:在线正常接收消息,离线不会有推送通知,可用于实现消息免打扰功能

    • startHour: number

      免打扰开始时间:小时,取值范围[0 - 23]

    • startMinute: number

      免打扰开始时间:分钟,取值范围[0 - 59]

    • startSecond: number

      免打扰开始时间:秒,取值范围[0 - 59]

    • duration: number

      免打扰持续时长:单位:秒,取值范围 [0 - 246060].

    Returns Promise<void>

    Note

    请注意

    • 当 duration 的取值小于 246060 时,可用于实现重复免打扰,即消息免打扰从每天的 startHour:startMinute:startSecond 表示的时间点开始,持续时长为 druation 秒
    • 当 duration 取值不小于 246060 时,可用于实现永久免打扰,即从调用该 API 当天 startHour:startMinute:startSecond 表示的时间点开始永久消息免打扰
  • 4.5 设置全局消息接收选项,从 7.4 版本开始支持。

    Parameters

    • opt: V2TIMReceiveMessageOpt

      全局消息接收选项,支持两种取值: V2TIMReceiveMessageOpt.V2TIM_RECEIVE_MESSAGE:在线正常接收消息,离线时会有厂商的离线推送通知,默认为该选项 V2TIMReceiveMessageOpt.V2TIM_RECEIVE_NOT_NOTIFY_MESSAGE:在线正常接收消息,离线不会有推送通知,可用于实现消息免打扰功能

    • startTimeStamp: number

      免打扰开始时间,UTC 时间戳,单位:秒

    • duration: number

      免打扰持续时长,单位:秒

    Returns Promise<void>

  • 5.1 获取历史消息高级接口

    Parameters

    Returns Promise<V2TIMMessage[]>

    Note

    请注意:

    • 如果没有触发登录,调用该接口不会返回历史消息
    • 如果登录失败,调用该接口会返回本地历史消息
    • 如果 SDK 检测到没有网络,调用该接口会返回本地历史消息
    • 如果登录成功且网络正常,当 option 设置为拉取云端历史消息,调用该接口会先请求云端历史消息,然后再和本地历史消息合并后返回
    • 只有会议群(Meeting)才能拉取到进群前的历史消息,直播群(AVChatRoom)消息不存漫游和本地数据库,调用这个接口无效
  • 5.2 撤回消息

    Parameters

    Returns Promise<void>

    Note

    请注意:

    • 撤回消息的时间限制默认 2 minutes,超过 2 minutes 的消息不能撤回,您也可以在 控制台(功能配置 -> 登录与消息 -> 消息撤回设置)自定义撤回时间限制。
    • 仅支持单聊和群组中发送的普通消息,无法撤销 onlineUserOnly 为 true 即仅在线用户才能收到的消息,也无法撤销直播群(AVChatRoom)中的消息。
    • 如果发送方撤回消息,已经收到消息的一方会收到 V2TIMAdvancedMsgListener::OnRecvMessageRevoked 回调。
    • 从 IMSDK 7.4 版本开始,支持撤回包括直播群(AVChatRoom)、社群在内的所有群类型的消息。
    • 在单聊场景中,仅能撤回自己的消息;在群聊场景中,除了可以撤回自己的消息外,管理员或者群主也可以撤回其他群成员的消息。
  • 5.3 消息变更

    Parameters

    Returns Promise<V2TIMMessage>

    Note

    请注意:

    • 如果消息修改成功,自己和对端用户(C2C)或群组成员(Group)都会收到 OnRecvMessageModified 回调。
    • 如果在修改消息过程中,消息已经被其他人修改,callback 会返回 ERR_SDK_MSG_MODIFY_CONFLICT 错误。
    • 消息无论修改成功或则失败,callback 都会返回最新的消息对象。
  • 5.4 删除本地及云端的消息

    Parameters

    Returns Promise<void>

    Note

    该接口删除本地及云端的消息,且无法恢复。需要注意的是:

    • 一次最多只能删除 50 条消息
    • 要删除的消息必须属于同一会话
    • 一秒钟最多只能调用一次该接口
    • 如果该账号在其他设备上拉取过这些消息,那么调用该接口删除后,这些消息仍然会保存在那些设备上,即删除消息不支持多端同步。
  • 5.5 清空单聊本地及云端的消息(不删除会话)

    5.4.666 及以上版本支持

    Parameters

    • userID: string

    Returns Promise<void>

    Note

    请注意:

    • 会话内的消息在本地删除的同时,在服务器也会同步删除。
  • 5.6 清空群聊本地及云端的消息(不删除会话)

    5.4.666 及以上版本支持

    Parameters

    • groupID: string

    Returns Promise<void>

    Note

    请注意:

    • 会话内的消息在本地删除的同时,在服务器也会同步删除。
  • 5.7 向群组消息列表中添加一条消息

    该接口主要用于满足向群组聊天会话中插入一些提示性消息的需求,比如“您已经退出该群”,这类消息有展示 在聊天消息区的需求,但并没有发送给其他人的必要。 所以 InsertGroupMessageToLocalStorage() 相当于一个被禁用了网络发送能力的 SendMessage() 接口。

    Parameters

    Returns {
        msgID: string;
        promise: Promise<V2TIMMessage>;
    }

    msgID 消息唯一标识

    Note

    通过该接口 save 的消息只存本地,程序卸载后会丢失。

  • 5.8 向C2C消息列表中添加一条消息

    该接口主要用于满足向C2C聊天会话中插入一些提示性消息的需求,比如“您已成功发送消息”,这类消息有展示 在聊天消息去的需求,但并没有发送给对方的必要。 所以 InsertC2CMessageToLocalStorage()相当于一个被禁用了网络发送能力的 SendMessage() 接口。

    Parameters

    Returns {
        msgID: string;
        promise: Promise<V2TIMMessage>;
    }

    msgID 消息唯一表示

    Note

    通过该接口 save 的消息只存本地,程序卸载后会丢失。

  • 5.9 根据 messageID 查询指定会话中的本地消息

    Parameters

    • messageIDList: string[]

      消息 ID 列表

    Returns Promise<V2TIMMessage[]>

  • 5.12 发送消息已读回执(6.1 及其以上版本支持)

    Parameters

    Returns Promise<void>

    Note

    请注意:

    • 该功能为旗舰版功能,购买旗舰版套餐包后可使用,详见价格说明
    • 向群消息发送已读回执,需要您先到控制台打开对应的开关,详情参考文档 群消息已读回执
    • messageList 里的消息必须在同一个会话中。
    • 该接口调用成功后,会话未读数不会变化,消息发送者会收到 onRecvMessageReadReceipts 回调,回调里面会携带消息的最新已读信息。
  • 5.15 设置消息扩展(6.7 及其以上版本支持,需要您购买旗舰版套餐)

    Parameters

    • message: V2TIMMessage

      消息对象,消息需满足三个条件:1、消息发送前需设置 supportMessageExtension 为 true,2、消息必须是发送成功的状态,3、消息不能是社群(Community)和直播群(AVChatRoom)消息。

    • extensions: V2TIMMessageExtension[]

      扩展信息,如果扩展 key 已经存在,则修改扩展的 value 信息,如果扩展 key 不存在,则新增扩展。

    Returns Promise<V2TIMMessageExtensionResult[]>

    Note

    • 扩展 key 最大支持 100 字节,扩展 value 最大支持 1KB,单次最多支持设置 20 个扩展,单条消息最多可设置 300 个扩展。
    • 当多个用户同时设置或删除同一个扩展 key 时,只有第一个用户可以执行成功,其它用户会收到 23001 错误码和最新的扩展信息,在收到错误码和扩展信息后,请按需重新发起设置操作。
    • 我们强烈建议不同的用户设置不同的扩展 key,这样大部分场景都不会冲突,比如投票、接龙、问卷调查,都可以把自己的 userID 作为扩展 key。
  • 5.17 删除消息扩展(6.7 及其以上版本支持,需要您购买旗舰版套餐)

    Parameters

    • message: V2TIMMessage
    • keys: string[]

      消息扩展 key 列表, 单次最大支持删除 20 个消息扩展,如果设置为 nil ,表示删除所有消息扩展

    Returns Promise<V2TIMMessageExtensionResult[]>

    Note

    • 当多个用户同时设置或删除同一个扩展 key 时,只有第一个用户可以执行成功,其它用户会收到 23001 错误码和最新的扩展信息,在收到错误码和扩展信息后,请按需重新发起删除操作。
  • 5.18 添加消息回应(可以用于实现表情回复)(7.4 及其以上版本支持,需要您购买旗舰版套餐)

    表情回应功能是指对某条消息通过表情符号进行互动回应,我们可以看到每种表情的回应人数和回应人列表。

    目前常见的消息回应展示方式会有如下两种风格:

    风格一:

    ----------------------------

    | lucy, happy birthday! |

    ----------------------------

    | 😄 1 💐 2 👍🏻 10 |

    ----------------------------

    风格二:

    ------------------------------------------------

    | lucy, happy birthday! |

    ------------------------------------------------

    | 😁 bob 💐olivia 🎂david |

    | 👍🏻 denny、james、lucy、linda、thomas 等10人 |

    ------------------------------------------------

    当用户点击某个表情后,会跳转到表情回应详情界面:

    | 😄 | 💐 | 👍🏻 |

    | bob | olivia | lucy |

    | ... | ... | denny |

    | ... | ... | ... |

    用户可以根据某个表情分页拉取使用该表情的用户信息。

    您可以基于 SDK API 实现表情回应能力:

    1、调用 AddMessageReaction 接口为一条消息添加一个 emoji,添加成功后,emoji 下就会存储当前操作用户。

    2、调用 RemoveMessageReaction 接口删除已经添加的 emoji,删除成功后,emoji 下就不再存储当前操作用户。

    3、调用 GetMessageReactions 接口批量拉取多条消息的 emoji 列表,其中每个 emoji 都包含了当前使用者总人数以及前 N(默认 10)个使用者用户资料。

    4、调用 GetAllUserListOfMessageReaction 接口分页拉取消息 emoji 的全量使用者用户资料。

    5、监听 onRecvMessageReactionsChanged 回调,感知 emoji 的使用者信息变更,该回调会携带 emoji 最新的使用者信息(包含使用者总人数以及前 N 个使用者用户资料)。

    Parameters

    • message: V2TIMMessage
    • reactionID: string

      消息回应 ID,在表情回复场景,reactionID 为表情 ID,单条消息最大支持 10 个 Reaction,单个 Reaction 最大支持 100 个用户。

    Returns Promise<void>

    Note

    • 该功能为旗舰版功能,需要您购买旗舰版套餐。
    • 如果单条消息 Reaction 数量超过最大限制,调用接口会报 ERR_SVR_MSG_REACTION_COUNT_LIMIT 错误。
    • 如果单个 Reaction 用户数量超过最大限制,调用接口会报 ERR_SVR_MSG_REACTION_USER_COUNT_LIMIT 错误。
    • 如果 Reaction 已经包含当前用户,调用接口会报 ERR_SVR_MSG_REACTION_ALREADY_CONTAIN_USER 错误。
  • 5.19 删除消息回应(7.4 及其以上版本支持,需要您购买旗舰版套餐)

    Parameters

    Returns Promise<void>

    Note

    • 如果 Reaction 不存在,调用接口会报 ERR_SVR_MSG_REACTION_NOT_EXISTS 错误。
    • 如果 Reaction 不包含当前用户,调用接口会报 ERR_SVR_MSG_REACTION_NOT_CONTAIN_USER 错误。
  • 5.20 批量拉取多条消息回应信息(7.4 及其以上版本支持,需要您购买旗舰版套餐)

    Parameters

    • messageList: V2TIMMessage[]

      消息列表,一次最大支持 20 条消息,消息必须属于同一个会话。

    • maxUserCountPerReaction: number

      取值范围 【0,10】,每个 Reaction 最多只返回前 10 个用户信息,如需更多用户信息,可以按需调用 getAllUserListOfMessageReaction 接口分页拉取。

    Returns Promise<V2TIMMessageReactionResult>

  • 5.21 分页拉取使用指定消息回应用户信息(7.4 及其以上版本支持,需要您购买旗舰版套餐)

    Parameters

    • message: V2TIMMessage

      消息对象

    • reactionID: string

      消息回应 ID

    • nextSeq: number

      分页拉取的游标,第一次传 0,后续分页传 succ 返回的 nextSeq。

    • count: number

      一次分页最大拉取个数,最大支持 100 个。

    Returns Promise<V2TIMMessageReactionUserResult>

  • 5.22 翻译文本消息

    Parameters

    • sourceTextList: string[]

      待翻译文本数组。

    • sourceLanguage: string

      源语言。可以设置为特定语言或 ”auto“。“auto“ 表示自动识别源语言。传空默认为 ”auto“。

    • targetLanguage: string

      目标语言。支持的目标语言有多种,例如:英语-“en“,简体中文-”zh“,法语-”fr“,德语-”de“等。详情请参考文档:文本翻译语言支持

    Returns Promise<Map<string, string>>

  • 5.23 设置群消息置顶(7.9 及以上版本支持,需要您购买旗舰版套餐)

    Parameters

    • groupID: string

      群 ID

    • message: V2TIMMessage
    • isPinned: boolean

      是否置顶

    Returns Promise<void>

    Note

    • 此接口用于置顶和取消置顶对应的群消息,如果置顶消息数量超出限制sdk会返回错误码10070。
  • 5.24 获取已置顶的群消息列表(7.9 及以上版本支持,需要您购买旗舰版套餐)

    Parameters

    • groupID: string

      群 ID

    Returns Promise<V2TIMMessage[]>

    Note

    • 此接口用于获取置顶消息列表,如果置顶消息已过期不会返回

Generated using TypeDoc