• UIKit
  • SDK
  • 服务端 API
Chat/
SDK/
Unity(Game Solution)/
消息/
SDK
  • 跑通Demo
  • SDK 集成
  • 初始化
  • 登录和注销
  • 消息
    • 消息概述
    • 发送消息
    • 接收消息
    • 历史消息
    • 转发消息
    • 修改消息
    • 删除消息
    • 清空消息
    • 撤回消息
    • 在线消息
    • 已读回执
    • 查询消息
    • 群 @ 消息
    • 定向群消息
    • 通知免打扰
    • 消息扩展
  • 会话
    • 会话概述
    • 会话列表
    • 获取会话
    • 未读会话数
    • 置顶会话
    • 删除会话
    • 会话草稿
    • 会话标记
    • 会话组
  • 群组
    • 群组概述
    • 群组管理
    • 群资料
    • 群成员管理
    • 群成员资料
    • 自定义群属性
    • 群计数器
  • 用户
    • 用户资料
    • 用户状态
    • 好友管理
    • 好友列表
    • 黑名单
  • Changelog
  • 开发指引
  • 控制台指南
    • 创建和升级应用
    • 基本配置
    • 功能配置
    • 账号管理
    • 群组管理
    • 回调配置
  • 产品介绍
    • 消息管理
      • 单聊消息
      • 消息存储
      • 离线推送
      • 群消息
      • 消息格式
    • 账号系统
      • 登陆验证
      • 在线状态管理
    • 群相关
      • 群组系统
      • 群组管理
    • 用户资料和关系链
      • 资料管理
      • 关系链管理
  • 购买指南
    • 计费概述
    • 价格中心
  • 错误码

转发消息

功能描述

如果您想实现合并转发功能,需要进行以下步骤:
1. 根据原始消息列表创建一条合并消息。
2. 把合并消息发送到对端。
3. 对端收到合并消息后解析出原始消息列表。

合并转发消息

创建并发送合并转发消息

我们在创建一条合并消息的时候不仅要设置合并消息列表,还要设置标题和摘要信息,实现流程如下:
1. 创建一条合并消息,创建合并消息的时候需要设置原始消息列表,合并消息标题、合并消息摘要等信息。
属性
含义
说明
merge_elem_message_array
原始消息列表
合并转发的原始消息列表
merge_elem_title
标题
合并消息的标题,如上图所示 “xixiyah 和 Hello 的聊天记录”
merge_elem_abstract_array
摘要列表
合并消息的摘要信息,如上图所示,合并消息需要预先展示原始消息的摘要信息,当用户点击 Cell 后才去展示完整消息内容
merge_elem_compatible_text
兼容文本信息
低版本 SDK 如果不支持合并消息,默认会收到一条文本消息,文本消息的内容为 merge_elem_compatible_text
2. 创建并发送合并消息示例代码如下:
// 需要被转发的消息列表,消息列表里可以包含合并消息,不能包含群 Tips 消息
var message = new Message
{
message_conv_id = conv_id,
message_conv_type = TIMConvType.kTIMConv_Group,
message_elem_array = new List<Elem>{
new Elem
{
elem_type = TIMElemType.kTIMElem_Merge,
merge_elem_title = "user1与user2的聊天", // 合并消息标题
merge_elem_message_array = new List<Message>
{
message1,
message2
},
merge_elem_abstract_array = new List<string>
{
"user1:hello", "user2:你好" // 合并消息摘要列表
},
merge_elem_compatible_text = "当前版本不支持该消息" // 合并消息兼容文本,低版本 SDK 如果不支持合并消息,默认会收到一条文本消息,文本消息的内容为 compatibleText
}},
};
StringBuilder messageId = new StringBuilder(128);
TIMResult res = TencentIMSDK.MsgSendMessage(conv_id, TIMConvType.kTIMConv_Group, message, messageId, (int code, string desc, string json_param, string user_data)=>{
// 消息发送异步结果
});


接收合并转发消息

添加监听器

接收方调用 AddRecvNewMsgCallback (点击查看详情) 添加消息监听器。 一般建议在比较靠前的时间点调用,例如例如聊天消息界面初始化后,确保 App 能及时收到消息。
示例代码如下:
TencentIMSDK.AddRecvNewMsgCallback((List<Message> messages, string user_data)=>{
foreach(Message message in messages)
{
foreach (Elem elem in message.message_elem_array)
{
// 有下一个消息
if (elem.elem_type == TIMElemType.kTIMElem_Merge)
{
}
}
}
})

解析消息

添加监听器后,接收方会在 RecvNewMsgCallback 中收到合并消息 Message。 可以先通过合并消息元素获取 merge_elem_titlemerge_elem_abstract_array UI 展示。 当用户点击合并消息的时候再调用 MsgDownloadMergerMessage(点击查看详情) 接口下载合并消息列表 UI 展示。
示例代码如下:
if(elem.TIMElemType == TIMElemType.kTIMElem_Merge){
elem.merge_elem_abstract_array;
elem.merge_elem_layer_over_limit;
elem.merge_elem_title;
TIMResult res = TencentIMSDK.MsgDownloadMergerMessage(message, (int code, string desc, List<Message> messages, string user_data)=>{
// 处理异步逻辑
});
}

逐条转发消息

如果您需要转发单条消息,可以先创建一条和原消息内容完全一样的转发消息,再调用 MsgSendMessage (点击查看详情) 接口把转发消息发送出去。