104 lines
4.2 KiB
Markdown
104 lines
4.2 KiB
Markdown
# 定制最近联系人列表
|
||
|
||
RecentContactsFragment 实现了默认的列表点击事件处理,点击列表项将会直接跳转至默认的单聊或者群聊界面,若默认实现无法满足需求,开发者可以参照下文定制最近联系人列表来实现,详细可以参照云信 Demo。
|
||
|
||
## 界面布局
|
||
|
||
最近联系人的布局属性如下图所示:
|
||
|
||

|
||
|
||
|属性|说明|
|
||
|:---|:---|
|
||
|network_status_bar|网络状态背景条|
|
||
|status_desc_label|网络状态文字说明|
|
||
|img_head|头像|
|
||
|tv_nickname|昵称|
|
||
|tv_online_state|在线状态|
|
||
|tv_message|消息内容|
|
||
|tv_date_time|时间戳|
|
||
|img_msg_status|消息发送状态|
|
||
|unread_number_tip|未读红点,占坑用|
|
||
|unread_number_explosion|未读红点,全屏动画时使用|
|
||
|
||
## 深度定制
|
||
|
||
开发者也可以通过设置自定义事件回调函数 RecentContactsCallback 来定制,目前支持:
|
||
|
||
1\. 最近联系人列表数据加载完成的回调函数(默认不作处理)。
|
||
|
||
2\. 有未读数更新时的回调函数,供更新除最近联系人列表外的其他界面和未读指示(默认不作处理)。
|
||
|
||
3\. 最近联系人点击响应回调函数,以供打开会话窗口时传入定制化参数,或者做其他动作(默认跳转至聊天窗口)。
|
||
|
||
4\. 设置自定义消息的摘要消息,展示在最近联系人列表的消息缩略栏上。当然,你也可以自定义一些内建消息的缩略语,例如图片,语音,音视频会话等,自定义的缩略语会被优先使用。
|
||
|
||
5\. 设置Tip消息的摘要信息,展示在最近联系人列表的消息缩略栏上。
|
||
|
||
如下是云信 Demo对最近联系人列表的定制:
|
||
|
||
```java
|
||
// 设置自定义事件回调函数
|
||
contactsFragment.setCallback(new RecentContactsCallback() {
|
||
@Override
|
||
public void onRecentContactsLoaded() {
|
||
// 最近联系人列表加载完毕
|
||
}
|
||
|
||
@Override
|
||
public void onUnreadCountChange(int unreadCount) {
|
||
// 未读数发生变化
|
||
ReminderManager.getInstance().updateSessionUnreadNum(unreadCount);
|
||
}
|
||
|
||
@Override
|
||
public void onItemClick(RecentContact recent) {
|
||
// 回调函数,以供打开会话窗口时传入定制化参数,或者做其他动作
|
||
switch (recent.getSessionType()) {
|
||
case P2P:
|
||
SessionHelper.startP2PSession(getActivity(), recent.getContactId());
|
||
break;
|
||
case Team:
|
||
SessionHelper.startTeamSession(getActivity(), recent.getContactId());
|
||
break;
|
||
default:
|
||
break;
|
||
}
|
||
}
|
||
|
||
@Override
|
||
public String getDigestOfAttachment(MsgAttachment attachment) {
|
||
// 设置自定义消息的摘要消息,展示在最近联系人列表的消息缩略栏上
|
||
// 当然,你也可以自定义一些内建消息的缩略语,例如图片,语音,音视频会话等,自定义的缩略语会被优先使用。
|
||
if (attachment instanceof GuessAttachment) {
|
||
GuessAttachment guess = (GuessAttachment) attachment;
|
||
return guess.getValue().getDesc();
|
||
} else if (attachment instanceof RTSAttachment) {
|
||
RTSAttachment rts = (RTSAttachment) attachment;
|
||
return rts.getContent();
|
||
} else if (attachment instanceof StickerAttachment) {
|
||
return "[贴图]";
|
||
} else if (attachment instanceof SnapChatAttachment) {
|
||
return "[阅后即焚]";
|
||
}
|
||
return null;
|
||
}
|
||
|
||
@Override
|
||
public String getDigestOfTipMsg(RecentContact recent) {
|
||
// 设置Tip消息的摘要信息,展示在最近联系人列表的消息缩略栏上
|
||
String msgId = recent.getRecentMessageId();
|
||
List<String> uuids = new ArrayList<>(1);
|
||
uuids.add(msgId);
|
||
List<IMMessage> msgs = NIMClient.getService(MsgService.class).queryMessageListByUuidBlock(uuids);
|
||
if (msgs != null && !msgs.isEmpty()) {
|
||
IMMessage msg = msgs.get(0);
|
||
Map<String, Object> content = msg.getRemoteExtension();
|
||
if (content != null && !content.isEmpty()) {
|
||
return (String) content.get("content");
|
||
}
|
||
}
|
||
return null;
|
||
}
|
||
});
|
||
``` |