1. RecyclerView

RecyclerView是5.0版本出现的控件,用来替代传统的ListView,更加强大和灵活。需要添加Design依赖库,并且使用Theme.AppCompat主题。

<?xml version="1.0" encoding="utf-8"?>    

在使用RecyclerView时候,必须指定一个适配器Adapter和一个布局管理器LayoutManager

RecyclerView recyclerView = findViewById(R.id.recycler_view);// 设置布局方式RecyclerView.LayoutManager layoutManager = new LinearLayoutManager(this);recyclerView.setLayoutManager(layoutManager);recyclerView.setAdapter(new RecyclerViewAdapter(this));

显示如下

2. 适配器

RecyclerView的适配器必须继承RecyclerView.Adapter,并且封装了ViewHolder的回收复用。

需要实现三个方法

  • VH onCreateViewHolder(ViewGroup parent, int viewType),为每个Item创建一个新的ViewHolder
  • void onBindViewHolder(VH holder, int position),为每个Item赋值
  • int getItemCount(),返回数量

基本适配器实现如下

public final class RecyclerViewAdapter extends RecyclerView.Adapter {    private Context mContext;    private List mContent = new ArrayList<>();    public RecyclerViewAdapter(Context context) {        this.mContext = context;        for (int position = 1; position <= 40; position++) {            mContent.add("This is " + position + " item");        }    }    @NonNull    @Override    public ItemViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int viewType) {        return new ItemViewHolder(LayoutInflater.from(mContext)                .inflate(R.layout.list_item_text, viewGroup, false));    }    @Override    public void onBindViewHolder(@NonNull ItemViewHolder viewHolder, int position) {        viewHolder.textView.setText(mContent.get(position));    }    @Override    public int getItemCount() {        return mContent.size();    }    class ItemViewHolder extends RecyclerView.ViewHolder {        private TextView textView;        public ItemViewHolder(@NonNull View itemView) {            super(itemView);            textView = itemView.findViewById(R.id.tv_content);        }    }}

3. 布局管理器

RecyclerView提供了三种布局管理器LayoutManager

  • LinerLayoutManager,以垂直或者水平列表方式展示Item
  • GridLayoutManager,以网格方式展示Item
  • StaggeredGridLayoutManager,以瀑布流方式展示Item

3.1 LinerLayoutManager

默认的LinerLayoutManager布局是垂直方向的,调用setOrientation()方法可以改变方向。

LinearLayoutManager layoutManager = new LinearLayoutManager(this);layoutManager.setOrientation(RecyclerView.HORIZONTAL);

效果如下

3.2 GridLayoutManager

GridLayoutManager布局需要指定网格的数量

LinearLayoutManager layoutManager = new GridLayoutManager(this, 4);

效果如下

3.3 StaggeredGridLayoutManager

StaggeredGridLayoutManager是瀑布流布局,根据布局的列数来自动适配宽度。

LinearLayoutManager layoutManager = new StaggeredGridLayoutManager(4, RecyclerView.VERTICAL);

效果如下

4. 添加列表头和列表尾

RecyclerView默认没有提供类似addHeaderView()addFooterView()这样的操作,我们只能自己实现。

首先我们需要准备两个ViewHolder,分别存放列表内容和表头表尾,拥有共同的父类ItemViewHolder

class ItemViewHolder extends RecyclerView.ViewHolder {    public ItemViewHolder(@NonNull View itemView) {        super(itemView);    }    // 为每个Item赋值    protected void bindViewHolder(int position) {    }}private class ContentViewHolder extends ItemViewHolder {    private TextView textView;    public ContentViewHolder(@NonNull View itemView) {        super(itemView);        textView = itemView.findViewById(R.id.tv_content);    }    @Override    protected void bindViewHolder(int position) {        textView.setText(mContent.get(position));    }}private class HeaderFooterView extends ItemViewHolder {    public HeaderFooterView(@NonNull View itemView) {        super(itemView);    }}

然后我们在getItemViewType()里面,根据不同的行号返回不同的ViewType。将ViewType分为列表内容和表头表尾,对应不同的ItemViewHolder。调用bindViewHolder()方法更新内容。

public final class RecyclerViewAdapter extends RecyclerView.Adapter {    private static final int VIEW_TYPE_HEADER_VIEW      = 100;    private static final int VIEW_TYPE_CONTENT_VIEW     = 200;    private static final int VIEW_TYPE_FOOTER_VIEW      = 300;    private Context mContext;    private List mContent = new ArrayList<>();    private List mHeaderViewList = new ArrayList<>();    private List mFooterViewList = new ArrayList<>();    public RecyclerViewAdapter(Context context) {        this.mContext = context;        for (int position = 1; position <= 20; position++) {            mContent.add("This is " + position + " item");        }    }    @Override    public int getItemViewType(int position) {        if (position < getHeaderViewSize()) {            // 表头的ViewType为1xx            return VIEW_TYPE_HEADER_VIEW + position;        } else if (position >= getHeaderViewSize() + mContent.size()) {            // 表尾的ViewType为3xx            return VIEW_TYPE_FOOTER_VIEW + position - getHeaderViewSize() - mContent.size();        } else {            // 内容的ViewType为200            return VIEW_TYPE_CONTENT_VIEW;        }    }    @NonNull    @Override    public RecyclerViewAdapter.ItemViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int viewType) {        if (viewType == VIEW_TYPE_CONTENT_VIEW) {            // 返回内容ViewHolder            return new ContentViewHolder(LayoutInflater.from(mContext)                    .inflate(R.layout.list_item_text, viewGroup, false));        } else if (viewType < VIEW_TYPE_CONTENT_VIEW) {            // 返回表头ViewHolder            return new HeaderFooterView(mHeaderViewList.get(viewType - VIEW_TYPE_HEADER_VIEW));        } else {            // 返回表尾ViewHolder            return new HeaderFooterView(mFooterViewList.get(viewType - VIEW_TYPE_FOOTER_VIEW));        }    }    @Override    public void onBindViewHolder(@NonNull RecyclerViewAdapter.ItemViewHolder viewHolder, int position) {        if (position >= getHeaderViewSize()) {            // 更新Item内容            viewHolder.bindViewHolder(position - getHeaderViewSize());        }    }    @Override    public int getItemCount() {        return getHeaderViewSize() + mContent.size() + getFooterViewSize();    }    public void addHeaderView(View headerView) {        this.mHeaderViewList.add(headerView);    }    public void addFooterView(View footerView) {        this.mFooterViewList.add(footerView);    }    private int getHeaderViewSize() {        return mHeaderViewList.size();    }    private int getFooterViewSize() {        return mFooterViewList.size();    }}

效果如下

相关文章
Android RecyclerView控件
Android RecyclerView刷新和加载

更多相关文章

  1. Android换肤Demo
  2. Android中自定义适配器的使用
  3. 关于Android(安卓)7.0下Launcher3下default_workspace.xml修改无
  4. ScrollView中的控件占据ScrollView的match_parent
  5. Android(安卓)Material Design Library系列教程(三)
  6. [安卓开发Android][叠层 层叠 卡片效果]RecyclerView与CardView
  7. [置顶] Android(安卓)ListView 基础入门 简介以及深入优化
  8. 【android studio】解决layout预览出现Rendering Problems Excep
  9. Android:TextView的垂直滚动效果,和上下滚动效果

随机推荐

  1. Android(安卓)AndroidProgressLayout:加载
  2. android中的反编译
  3. Android(安卓)和 iOS 版 Quickoffice 都
  4. 【Android(安卓)开发】:UI控件之 ImageVie
  5. android手机短信发送
  6. Android(安卓)init 启动过程分析(一)
  7. 以php开发服务器后台的android即时通讯ap
  8. Android从系统Gallery获取图片具体实现
  9. Android系统堆内存限制浅析
  10. Android的反射机制Reflection