EMConversation class

会话类,用于定义单聊会话、群聊会话和聊天室会话。每类会话中包含发送和接收的消息。

以下示例代码展示如何从会话中获取未读消息数:

  // The `ConversationId` can be the other party ID, the group ID, or the chat room ID.
  EMConversation? con = await EMClient.getInstance.chatManager.getConversation(conversationId);
  int? unreadCount = con?.unreadCount;

Constructors

EMConversation.fromJson(Map<String, dynamic> map)
factory

Properties

ext Map<String, String>?
获取会话扩展属性。
no setter
hashCode int
The hash code for this object.
no setterinherited
id String
获取会话 ID。
final
isChatThread bool
是否为子区会话。
final
isPinned bool
是否为置顶会话:
final
marks List<ConversationMarkType>?
会话标记。
final
pinnedTime int
会话置顶的 UNIX 时间戳,单位为毫秒。未置顶时值为 0
final
runtimeType Type
A representation of the runtime type of the object.
no setterinherited
type EMConversationType
会话类型。
final

Methods

appendMessage(EMMessage message) Future<void>
插入一条消息到会话尾部。
deleteAllMessages() Future<void>
同时从内存和本地数据库中删除会话中的所有消息。
deleteLocalAndServerMessages({required List<String> msgIds}) Future<void>
通过消息 ID 从本地和服务器删除消息。
deleteLocalAndServerMessagesByTime({required int beforeMs}) Future<void>
通过消息时间戳从本地和服务器删除消息。
deleteMessage(String messageId) Future<void>
删除会话中的一条消息,同时清除内存和数据库中的消息。
deleteMessageByIds(List<String> messageIds) Future<void>
根据时间删除本地消息。
deleteMessagesWithTs(int startTs, int endTs) Future<void>
从本地数据库中删除指定时间段内的消息。
getLocalMessageCount({required int startMs, required int endMs}) Future<int>
获取本地消息数量。
insertMessage(EMMessage message) Future<void>
插入一条消息在 SDK 本地数据库,消息的 conversation ID 应该和会话的 conversation ID 一致,消息会根据消息里的时间戳被插入 SDK 本地数据库,并且更新会话的 latestMessage 等属性。
lastReceivedMessage() Future<EMMessage?>
获取最近收到的一条消息。
latestMessage() Future<EMMessage?>
获取会话的最新一条消息。
loadMessage(String messageId) Future<EMMessage?>
获取指定 ID 的消息。
loadMessages({String startMsgId = '', int loadCount = 20, EMSearchDirection direction = EMSearchDirection.Up}) Future<List<EMMessage>>
从本地数据库加载消息。
loadMessagesFromTime({required int startTime, required int endTime, int count = 20}) Future<List<EMMessage>>
加载一个时间段内的消息,不超过最大数量。
loadMessagesWithKeyword(String keywords, {String? sender, int timestamp = -1, int count = 20, MessageSearchScope searchScope = MessageSearchScope.All, EMSearchDirection direction = EMSearchDirection.Up}) Future<List<EMMessage>>
根据消息中的关键词、消息时间戳、要搜索的消息条数、搜索范围和搜索方向从 SDK 本地数据库中搜索指定数量的消息。
loadMessagesWithMsgType({required MessageType type, int timestamp = -1, int count = 20, String? sender, EMSearchDirection direction = EMSearchDirection.Up}) Future<List<EMMessage>>
根据消息类型、搜索消息的时间点、搜索结果的最大条数、搜索来源和搜索方向从 SDK 本地数据库中搜索指定数量的消息。
loadPinnedMessages() Future<List<EMMessage>>
获取会话内的置顶消息列表。
markAllMessagesAsRead() Future<void>
将所有消息标为已读。
markMessageAsRead(String messageId) Future<void>
将消息标为已读。
messagesCount() Future<int>
会话中的消息数
noSuchMethod(Invocation invocation) → dynamic
Invoked when a nonexistent method or property is accessed.
inherited
remindType() Future<ChatPushRemindType>
会话免打扰类型。ChatPushRemindType
searchMsgsByOptions(MessageSearchOptions options) Future<List<EMMessage>>
通过类型从数据库获取消息。
setExt(Map<String, String>? ext) Future<void>
设置会话扩展属性。
toString() String
A string representation of this object.
inherited
unreadCount() Future<int>
获取会话的消息未读数。
updateMessage(EMMessage message) Future<void>
更新 SDK 本地数据库的消息。

Operators

operator ==(Object other) bool
The equality operator.
inherited