用户信息
要在 Global IM UIKit UI 上展示用户头像、昵称等,需要应用层(App)主动向 Global IM UIKit SDK 提供用户信息(UserInfo
)。
Global IM UIKit 使用 UserInfoConfig
类统一管理以下数据。App 需要使用 UserInfoConfig
向 Global IM UIKit 提供数据,用于在 UI 上展示。
- 用户信息:包含昵称、头像
- 群组信息:包含群组名称、群组头像
- 群成员用户信息:仅支持群用户昵称
用户信息、群组信息、群成员用户信息必须由应用开发者主动从 App 服务端获取,并提供给 SDK。融云不提供 App 用户与群组信息托管服务。融云服务端的用户昵称及头像仅用于推送服务。
本文仅描述了应用层(App)如何为 Global IM UIKit SDK 提供用户昵称与头像(UserInfo
):
UserInfo userInfo = new UserInfo(userId, "userId 对应的名称", Uri.parse("userId 对应头像地址"));
刷新用户信息
如果 App 本地持有用户信息数据(例如当前登录用户的昵称和头像),可直接刷新本地缓存和数据库中存储的用户信息(头像与昵称)。刷新后,Global IM UIKit UI 会展示最新的用户信息 UserInfo
。
刷新用户信息必须在 Global IM UIKit 已成功建立 IM 连接后操作,否则无法刷新本地数据。可能适用场景如下:
- App 首次启动,并成功建立 IM 连接以后,可以将自身业务所需的用户信息批量提供给 SDK,由 SDK 写入缓存与本地数据库,供后续使用。
- 在 IM 建立连接后,如果用户昵称、头像等信息变动,由 App 服务端通知客户端(例如使用消息),客户端调用接口刷新用户信息。
UserInfo userInfo = new UserInfo(userId, "userId 对应的名称", Uri.parse("userId 对应头像地址"));
ConfigCenter.getUserInfoConfig().refreshUserInfoCache(userInfo);
如果 App 本地不持有数据,推荐在 Global IM UIKit 需要展示数据时动态提供用户信息。
动态提供用户信息
从 Global IM UIKit 5.X 版本开始,SDK 设计了「用户信息提供者」UserDataProvider.UserInfoProvider
接口类。如果 Global IM UIKit 无法从 UserInfoConfig
中获取用户信息,将触发 UserInfoProvider
的 getUserInfo
回调方法。App 应在该回调中提供 SDK 所需要的用户头像与昵称。
获取用户信息数据后,SDK 会自动设置、刷新用户头像与昵称,以及实现相关 UI 展示。
public interface UserInfoProvider {
/**
* 获取用户信息。
*
* @param userId 用户 Id。
* @return 用户信息。
*/
UserInfo getUserInfo(String userId);
}