ZIM 升级指南
本文介绍 ZIM Web/小程序 SDK 版本升级时的一些说明和注意事项。
2.19.0 升级指南
从 2.19.0 版本开始,以下接口有重大变更,因此在从旧版本升级到 2.19.0 版本时,请您阅读以下指南。
sendMediaMessage
自 2.19.0 版本后,发送多媒体消息需使用 sendMessage 接口。sendMediaMessage
接口被废弃,以实现发送消息的统一性和便于后续的通用扩展。
ZIMMessageSendNotification 中,onMediaUploadingProgress 回调方法的 message
参数类型从 ZIMMessage
变更为 ZIMMediaMessage
,以确保仅媒体消息会被回调通知,Typescript 开发者需要根据 IDE 的编译错误提示修正调用。(目前仅使用 Typescripts 开发语言且使用了 replyMessage 接口的开发者会受到需要解决编译报错的影响)。
const imageMessage: ZIMMessageBase = {
type: ZIMMessageType.Image,
fileLocalPath: file
}
const config: ZIMMessageSendConfig = {
priority: ZIMMessagePriority.Medium
}
const notification: ZIMMessageSendNotification = {
onMessageAttached: (message: ZIMMessage) => {
// 开发者可以监听这个回调执行消息发送前的业务逻辑
},
onMessageUploadingProgress: (message: ZIMMediaMessage, currentFileSize: number, totalFileSize: number) => {
// 多媒体上传进度
}
}
zim.sendMessage(imageMessage, "TO_CONVERSATION_ID", ZIMConversationType.Peer, config, notification).then((message: ZIMMessage) => {
// 消息发送结果
}).catch((errorInfo: ZIMError) => {
// 消息发送失败
})
const imageMessage: ZIMMessageBase = {
type: ZIMMessageType.Image,
fileLocalPath: file
}
const config: ZIMMessageSendConfig = {
priority: ZIMMessagePriority.Medium
}
const notification: ZIMMediaMessageSendNotification = {
onMessageAttached: (message: ZIMMediaMessage) => {
// 开发者可以监听这个回调执行消息发送前的业务逻辑
},
onMessageUploadingProgress: (message: ZIMMediaMessage, currentFileSize: number, totalFileSize: number) => {
// 多媒体上传进度
}
}
zim.sendMediaMessage(imageMessage, "TO_CONVERSATION_ID", ZIMConversationType.Peer, config, notification).then((message: ZIMMessage) => {
// 消息发送结果
}).catch((errorInfo: ZIMError) => {
// 消息发送失败
})
2.18.0 升级指南
从 2.18.0 版本开始,以下接口有重大变更,因此在从旧版本升级到 2.18.0 版本时,请您阅读以下指南。
单聊消息接收回调
原单聊消息接收回调 receivePeerMessage
已被废弃,请使用 peerMessageReceived 代替。
新回调支持以下功能:
- 用户在线时,可通过此回调接收在线单聊消息。
- 用户重新登录 ZIM SDK 后,可以通过此回调接收离线期间(最长7天)收到的所有单聊消息。
//新接口
peerMessageReceived: (zim: ZIM, data: ZIMEventOfConversationMessageReceivedResult) => void;
//老接口
receivePeerMessage: (zim: ZIM, data: ZIMEventOfReceiveConversationMessageResult) => void;
房间消息接收回调
原房间消息接收回调 receiveRoomMessage
已被废弃,请使用 roomMessageReceived 代替。
新回调支持以下功能:
- 用户在线时,可通过此回调接收在线房间消息。
- 用户从离线恢复到在线后,若仍在房间中,即可通过此回调接收离线期间内的所有房间消息。
//新接口
roomMessageReceived: (zim: ZIM, data: ZIMEventOfConversationMessageReceivedResult) => void;
//老接口
receiveRoomMessage: (zim: ZIM, data: ZIMEventOfReceiveConversationMessageResult) => void;
群组消息接收回调
原群组消息接收回调 receiveGroupMessage
已被废弃,请使用 groupMessageReceived 代替。
新回调支持以下功能:
- 用户在线时,可通过此回调接收在线群组消息。
- 用户重新登录 ZIM SDK 后,可以通过通过此回调接收离线期间(最长7天)收到的所有群聊消息。
//新接口
groupMessageReceived: (zim: ZIM, data: ZIMEventOfConversationMessageReceivedResult) => void;
//老接口
receiveGroupMessage: (zim: ZIM, data: ZIMEventOfReceiveConversationMessageResult) => void;
2.16.0 升级指南
从 2.16.0 版本开始,以下接口有重大变更,因此在从旧版本升级到 2.16.0 版本时,请您阅读以下指南。
callCancel
以下变更仅对进阶模式呼叫邀请而言。
在新版本的 callCancel 中,如果参数 userIDs 包含一个 userID,则该接口将仅取消邀请该被叫用户。如果 userIDs 参数为空,则该接口将对所有被叫用户取消邀请。
而对于旧版本的 callCancel
接口,无论参数 userIDs 是否为空,均视为对所有被叫用户取消邀请。
由于旧版 ZIM SDK 不兼容单独取消逻辑,因此如果您既需要保留使用老版本 ZIM 实现的取消逻辑,又需要使用新版本的单独取消功能,请隔离新老版本 ZIM 之间的呼叫功能。
// 单独取消 userIdA 、userIdB
var callID = 'xxxx';
var invitees = ['userIdA','userIdB']; // 被邀请人ID列表
var config = { extendedData: 'xxxx' };
zim.callCancel(invitees, callID, config)
.then(res => {
// 操作成功
})
.catch(err => {
// 操作失败
})
// 取消整个呼叫邀请,当整个呼叫中所有被叫都未接受时可以调用成功
var callID = 'xxxx';
var invitees = []; // 被邀请人ID列表
var config = { extendedData: 'xxxx' };
zim.callCancel(invitees, callID, config)
.then(res => {
// 操作成功
})
.catch(err => {
// 操作失败
})
// 无论 userIDs 中是否传递 userID,均为取消整个呼叫,当整个呼叫中所有被叫都未接受时可以调用成功
var callID = 'xxxx';
var invitees = ['userIdA','userIdB']; // 被邀请人ID列表
var config = { extendedData: 'xxxx' };
zim.callCancel(invitees, callID, config)
.then(res => {
// 操作成功
})
.catch(err => {
// 操作失败
})
// 取消整个呼叫邀请,当整个呼叫中所有被叫都未接受时可以调用成功
var callID = 'xxxx';
var invitees = []; // 被邀请人ID列表
var config = { extendedData: 'xxxx' };
zim.callCancel(invitees, callID, config)
.then(res => {
// 操作成功
})
.catch(err => {
// 操作失败
})