获取未读消息数
超级群业务支持从客户端 SDK 获取未读消息数,具体如下:
- 当前用户加入的所有超级群、指定超级群、或指定频道未读消息数。
- 当前用户加入的所有超级群、指定超级群、或指定频道的未读 @ 消息数。
- 按免打扰级别获取总未读消息数
返回的未读数最大值为 999。如果实际未读数超过 999,接口仍返回 999。
获取多个超级群的未读消息数
SDK 支持获取当前用户加入的所有超级群中未读消息数与未读 @ 消息数。
批量获取当前用户的超级群的未读消息数
提示
SDK 从 5.4.6 版本开始支持该接口。仅在 ChannelClient 中提供。
在社群应用场景中,App 可能需要实时显示用户所在的多个超级群下所有频道的最新未读消息数据,可以使用 getUltraGroupConversationUnreadInfoList
一次获取最多 20 个超级群下所有频道的未读数据。具体包含:
- 超级群频道的未读消息数
- 超级群频道的未读 @ 消息数
- 超级群频道中仅 @ 当前用户的未读 @ 消息数
- 超级群频道的免打扰级别
Java
ChannelClient.getInstance().getUltraGroupConversationUnreadInfoList(targetIds,
new IRongCoreCallback.ResultCallback<List<ConversationUnreadInfo>>() {
@Override
public void onSuccess(List<ConversationUnreadInfo> ConversationUnreadInfos) {
if (ConversationUnreadInfos == null) return;
for (ConversationUnreadInfo unreadInfo : ConversationUnreadInfos) {
// 获取超级群会话类型
Conversation.ConversationType type = unreadInfo.getType();
String targetId = unreadInfo.getTargetId();
// 获取超级群频道 ID
String channelId = unreadInfo.getChannelId();
//获取频道内的未读消息数
int unreadMessageCount = unreadInfo.getUnreadMessageCount();
//获取频道内的 @ 未读消息数
int unreadMentionedCount =
unreadInfo.getUnreadMentionedCount();
//获取频道内仅自己被 @ 的未读消息数(@ 我)
int mentionedMeCount = unreadInfo.getUnreadMentionedMeCount();
//获取频道的免打扰级别设置
IRongCoreEnum.PushNotificationLevel pushNotificationLevel = getPushNotificationLevel();
}
//该回调在非 UI 线程返回,如果需要做 UI 操作,请切换至 UI 线程
}
@Override
public void onError(IRongCoreEnum.CoreErrorCode ErrorCode) {
}
});