写点什么

融云 ConversationListFragment 会话列表添加头部布局

发布于: 2021 年 03 月 15 日

公司需求, 需要使用融云 SDK 官方的 IMkit 去实现自己的效果, 其中一个就是在会话列表头部添加几个 item, 通过查看 ConversationListFragment 中的源码发现, 有一个 onAddHeaderView 方法, 可以在会话列表的 ListView 上添加 Header 头布局。 所以找到了实现方法。 步骤是这样的。


第一步 创建 MyConversationListFragment 继承 ConversationListFragment。


第二步 复写父类 onAddHeaderView 方法, 并添加返回自定义的布局.


class MyConversationListFragment extends ConversationListFragment {
复制代码


复制代码


  /**
复制代码


   * 会话列表添加头部
复制代码


   * @return 头部view
复制代码


   */
复制代码


  @Override
复制代码


  protected List<View> onAddHeaderView() {
复制代码


    List<View> headerViews = new ArrayList<>();
复制代码


    return headerViews;
复制代码


  }
复制代码


}
复制代码


复制代码

第三步. 创建了一个 top_item_view.xml 实现要头部的效果, 然后把此 view 通过 onAddHeaderView 返回给。


class MyConversationListFragment extends ConversationListFragment {
复制代码


    ...
复制代码


  /**
复制代码


   * 会话列表添加头部
复制代码


   * @return 头部view
复制代码


   */
复制代码


  @Override
复制代码


  protected List<View> onAddHeaderView() {
复制代码


    List<View> headerViews = new ArrayList<>();
复制代码


    View itemView = findByViewId(R.layout.top_item_view);
复制代码


    headerViews.add(itemView);
复制代码


    return headerViews;
复制代码


  }
复制代码


  
复制代码


  ...
复制代码


}
复制代码


复制代码

4. 然后在 Manifest.xml 中使用 MyConversationListFragment 替换 ConversationListFragment.


这样就给 ListView 添加上头布局了。 是不是很简单呢


用户头像

还未添加个人签名 2021.01.26 加入

还未添加个人简介

评论

发布
暂无评论
融云 ConversationListFragment 会话列表添加头部布局