|
abstract void | addAdvancedMsgListener (V2TIMAdvancedMsgListener listener) |
|
abstract void | removeAdvancedMsgListener (V2TIMAdvancedMsgListener listener) |
|
abstract V2TIMMessage | createTextMessage (String text) |
|
abstract V2TIMMessage | createTextAtMessage (String text, List< String > atUserList) |
|
abstract V2TIMMessage | createCustomMessage (byte[] data) |
|
abstract V2TIMMessage | createCustomMessage (byte[] data, String description, byte[] extension) |
|
abstract V2TIMMessage | createImageMessage (String imagePath) |
|
abstract V2TIMMessage | createSoundMessage (String soundPath, int duration) |
|
abstract V2TIMMessage | createVideoMessage (String videoFilePath, String type, int duration, String snapshotPath) |
|
abstract V2TIMMessage | createFileMessage (String filePath, String fileName) |
|
abstract V2TIMMessage | createLocationMessage (String desc, double longitude, double latitude) |
|
abstract V2TIMMessage | createFaceMessage (int index, byte[] data) |
|
abstract V2TIMMessage | createMergerMessage (List< V2TIMMessage > messageList, String title, List< String > abstractList, String compatibleText) |
|
abstract V2TIMMessage | createForwardMessage (V2TIMMessage message) |
|
abstract V2TIMMessage | createTargetedGroupMessage (V2TIMMessage message, List< String > receiverList) |
|
abstract V2TIMMessage | createAtSignedGroupMessage (V2TIMMessage message, List< String > atUserList) |
|
abstract String | sendMessage (V2TIMMessage message, String receiver, String groupID, int priority, boolean onlineUserOnly, V2TIMOfflinePushInfo offlinePushInfo, V2TIMSendCallback< V2TIMMessage > callback) |
|
abstract void | setC2CReceiveMessageOpt (List< String > userIDList, int opt, V2TIMCallback callback) |
|
abstract void | getC2CReceiveMessageOpt (List< String > userIDList, V2TIMValueCallback< List< V2TIMReceiveMessageOptInfo >> callback) |
|
abstract void | setGroupReceiveMessageOpt (String groupID, int opt, V2TIMCallback callback) |
|
abstract void | setAllReceiveMessageOpt (int opt, int startHour, int startMinute, int startSecond, long duration, V2TIMCallback callback) |
|
abstract void | setAllReceiveMessageOpt (int opt, long startTimeStamp, long duration, V2TIMCallback callback) |
|
abstract void | getAllReceiveMessageOpt (V2TIMValueCallback< V2TIMReceiveMessageOptInfo > callback) |
|
abstract void | getC2CHistoryMessageList (String userID, int count, V2TIMMessage lastMsg, V2TIMValueCallback< List< V2TIMMessage >> callback) |
|
abstract void | getGroupHistoryMessageList (String groupID, int count, V2TIMMessage lastMsg, V2TIMValueCallback< List< V2TIMMessage >> callback) |
|
abstract void | getHistoryMessageList (V2TIMMessageListGetOption option, V2TIMValueCallback< List< V2TIMMessage >> callback) |
|
abstract void | revokeMessage (V2TIMMessage msg, V2TIMCallback callback) |
|
abstract void | modifyMessage (V2TIMMessage msg, V2TIMCompleteCallback< V2TIMMessage > callback) |
|
abstract void | deleteMessageFromLocalStorage (V2TIMMessage msg, V2TIMCallback callback) |
|
abstract void | deleteMessages (List< V2TIMMessage > messages, V2TIMCallback callback) |
|
abstract void | clearC2CHistoryMessage (String userID, V2TIMCallback callback) |
|
abstract void | clearGroupHistoryMessage (String groupID, V2TIMCallback callback) |
|
abstract String | insertGroupMessageToLocalStorage (V2TIMMessage msg, String groupID, String sender, V2TIMValueCallback< V2TIMMessage > callback) |
|
abstract String | insertC2CMessageToLocalStorage (V2TIMMessage msg, String userID, String sender, V2TIMValueCallback< V2TIMMessage > callback) |
|
abstract void | findMessages (List< String > messageIDList, V2TIMValueCallback< List< V2TIMMessage >> callback) |
|
abstract void | searchLocalMessages (V2TIMMessageSearchParam searchParam, V2TIMValueCallback< V2TIMMessageSearchResult > callback) |
|
abstract void | searchCloudMessages (V2TIMMessageSearchParam searchParam, V2TIMValueCallback< V2TIMMessageSearchResult > callback) |
|
abstract void | sendMessageReadReceipts (List< V2TIMMessage > messageList, V2TIMCallback callback) |
|
abstract void | getMessageReadReceipts (List< V2TIMMessage > messageList, V2TIMValueCallback< List< V2TIMMessageReceipt >> callback) |
|
abstract void | getGroupMessageReadMemberList (V2TIMMessage message, int filter, long nextSeq, int count, V2TIMValueCallback< V2TIMGroupMessageReadMemberList > callback) |
|
abstract void | setMessageExtensions (V2TIMMessage message, List< V2TIMMessageExtension > extensions, V2TIMValueCallback< List< V2TIMMessageExtensionResult >> callback) |
|
abstract void | getMessageExtensions (V2TIMMessage message, V2TIMValueCallback< List< V2TIMMessageExtension >> callback) |
|
abstract void | deleteMessageExtensions (V2TIMMessage message, List< String > keys, V2TIMValueCallback< List< V2TIMMessageExtensionResult >> callback) |
|
abstract void | addMessageReaction (V2TIMMessage message, String reactionID, V2TIMCallback callback) |
|
abstract void | removeMessageReaction (V2TIMMessage message, String reactionID, V2TIMCallback callback) |
|
abstract void | getMessageReactions (List< V2TIMMessage > messageList, int maxUserCountPerReaction, V2TIMValueCallback< List< V2TIMMessageReactionResult >> callback) |
|
abstract void | getAllUserListOfMessageReaction (V2TIMMessage message, String reactionID, int nextSeq, int count, V2TIMValueCallback< V2TIMMessageReactionUserResult > callback) |
|
abstract void | translateText (List< String > sourceTextList, String sourceLanguage, String targetLanguage, V2TIMValueCallback< HashMap< String, String >> callback) |
|
abstract void | pinGroupMessage (String groupID, V2TIMMessage message, boolean isPinned, V2TIMCallback callback) |
|
abstract void | getPinnedGroupMessageList (String groupID, V2TIMValueCallback< List< V2TIMMessage >> callback) |
|
abstract void | markC2CMessageAsRead (String userID, V2TIMCallback callback) |
|
abstract void | markGroupMessageAsRead (String groupID, V2TIMCallback callback) |
|
abstract void | markAllMessageAsRead (V2TIMCallback callback) |
|
abstract V2TIMMessage createMergerMessage |
( |
List< V2TIMMessage > |
messageList, |
|
|
String |
title, |
|
|
List< String > |
abstractList, |
|
|
String |
compatibleText |
|
) |
| |
|
abstract |
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 接口获取转发消息列表。
- 参数
-
messageList | 消息列表(最大支持 300 条,消息对象必须是 V2TIM_MSG_STATUS_SEND_SUCC 状态,消息类型不能为 V2TIMGroupTipsElem) |
title | 合并消息的来源,比如 "vinson 和 lynx 的聊天记录"、"xxx 群聊的聊天记录"。 |
abstractList | 合并消息的摘要列表(最大支持 5 条摘要,每条摘要的最大长度不超过 100 个字符),不同的消息类型可以设置不同的摘要信息,比如: 文本消息可以设置为:sender:text,图片消息可以设置为:sender:[图片],文件消息可以设置为:sender:[文件]。 |
compatibleText | 合并消息兼容文本,低版本 SDK 如果不支持合并消息,默认会收到一条文本消息,文本消息的内容为 compatibleText, 该参数不能为 null。 |
5.21 添加消息回应(可以用于实现表情回应)(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 个使用者用户资料)。
- 参数
-
reactionID | 消息回应 ID,在表情回应场景,reactionID 为表情 ID,单条消息最大支持 10 个 Reaction,单个 Reaction 最大支持 100 个用户。 |
- 注意
- 该功能为旗舰版功能,需要您购买旗舰版套餐。
- 如果单条消息 Reaction 数量超过最大限制,调用接口会报 ERR_SVR_MSG_REACTION_COUNT_LIMIT 错误。
- 如果单个 Reaction 用户数量超过最大限制,调用接口会报 ERR_SVR_MSG_REACTION_USER_COUNT_LIMIT 错误。
- 如果 Reaction 已经包含当前用户,调用接口会报 ERR_SVR_MSG_REACTION_ALREADY_CONTAIN_USER 错误。