使用BaseRecyclerViewAdapterHelper

来源:互联网 发布:厨具 德国 知乎 编辑:程序博客网 时间:2024/06/06 02:53

一个强大并且灵活的RecyclerViewAdapter

它能做什么?

  • 它可以大量减少你Adapter写的代码(和正常的Adapter相比至少三分之二的)

  • 它可以很轻松的添加RecyclerView加载动画

  • 添加item点击事件

  • 新增添加头部、添加尾部

  • 新增下拉刷新、上拉加载更多

  • 新增分组

  • 自定义item类型

demo.gif

如何使用它?

先在 build.gradle 的 repositories 添加:

  1.     allprojects {
  2.         repositories {
  3.             ...
  4.             maven { url "https://jitpack.io" }
  5.         }
  6.     }

然后在dependencies添加:

  1.     dependencies {
  2.             compile 'com.github.CymChad:BaseRecyclerViewAdapterHelper:v1.5.3'
  3.     }

如何使用它来创建Adapter?

  1. public class QuickAdapter extends BaseQuickAdapter<Status> {
  2.     public QuickAdapter(Context context) {
  3.         super(context, R.layout.tweet, DataServer.getSampleData());
  4.     }
  5.  
  6.     @Override
  7.     protected void convert(BaseViewHolder helper, Status item) {
  8.         helper.setText(R.id.tweetName, item.getUserName())
  9.                 .setText(R.id.tweetText, item.getText())
  10.                 .setText(R.id.tweetDate, item.getCreatedAt())
  11.                 .setImageUrl(R.id.tweetAvatar, item.getUserAvatar())
  12.                 .setVisible(R.id.tweetRT, item.isRetweet())
  13.                 .linkify(R.id.tweetText);
  14.     }
  15. }

这么复杂的布局只需要15行代码即可!

如何添加item点击事件?

  1. mQuickAdapter.setOnRecyclerViewItemClickListener(new BaseQuickAdapter.OnRecyclerViewItemClickListener() {
  2.             @Override
  3.             public void onItemClick(View view, int position) {
  4.                 //..
  5.             }
  6.         });

如何使用它添加动画?

  1. // 一行代码搞定(默认为渐显效果)
  2. quickAdapter.openLoadAnimation();

不喜欢渐显动画可以这样更换

  1. // 默认提供5种方法(渐显、缩放、从下到上,从左到右、从右到左)
  2. quickAdapter.openLoadAnimation(BaseQuickAdapter.ALPHAIN);

还是没你喜欢的,你可以自定义

  1. // 自定义动画如此轻松
  2. quickAdapter.openLoadAnimation(new BaseAnimation() {
  3.                             @Override
  4.                             public Animator[] getAnimators(View view) {
  5.                                 return new Animator[]{
  6.                                         ObjectAnimator.ofFloat(view, "scaleY", 1, 1.1f, 1),
  7.                                         ObjectAnimator.ofFloat(view, "scaleX", 1, 1.1f, 1)
  8.                                 };
  9.                             }
  10.                         });

使用它添加头部添加尾部

  1. mQuickAdapter.addHeaderView(getView());
  2. mQuickAdapter.addFooterView(getView());

使用它加载更多

  1. mQuickAdapter.setOnLoadMoreListener(PAGE_SIZE, new BaseQuickAdapter.RequestLoadMoreListener() {
  2.             @Override
  3.             public void onLoadMoreRequested() {
  4.                 if (mCurrentCounter >= TOTAL_COUNTER) {
  5.                     mRecyclerView.post(new Runnable() {
  6.                         @Override
  7.                         public void run() {
  8.                             mQuickAdapter.isNextLoad(false);
  9.                         }
  10.                     });
  11.                 } else {
  12.                     // reqData
  13.                     mCurrentCounter = mQuickAdapter.getItemCount();
  14.                     mQuickAdapter.isNextLoad(true);
  15.                 }
  16.             }
  17.         });

使用分组

  1. public class SectionAdapter extends BaseSectionQuickAdapter<MySection> {
  2.      public SectionAdapter(Context context, int layoutResId, int sectionHeadResId, List data) {        super(context, layoutResId, sectionHeadResId, data);
  3.     }
  4.     @Override    protected void convert(BaseViewHolder helper, MySection item) {
  5.         helper.setImageUrl(R.id.iv, (String) item.t);
  6.     }
  7.     @Override    protected void convertHead(BaseViewHolder helper,final MySection item) {
  8.         helper.setText(R.id.header, item.header);        if(!item.isMroe)helper.setVisible(R.id.more,false);        else
  9.         helper.setOnClickListener(R.id.more, new View.OnClickListener() {
  10.             @Override            public void onClick(View v) {
  11.                 Toast.makeText(context,item.header+"more..",Toast.LENGTH_LONG).show();
  12.             }
  13.         });
  14.     }12345678910111213141516171819201234567891011121314151617181920

自定义item类型

  1. public class SectionAdapter extends BaseSectionQuickAdapter<MySection> {
  2.      public SectionAdapter(Context context, int layoutResId, int sectionHeadResId, List data) {
  3.         super(context, layoutResId, sectionHeadResId, data);
  4.     }
  5.     @Override
  6.     protected void convert(BaseViewHolder helper, MySection item) {
  7.         helper.setImageUrl(R.id.iv, (String) item.t);
  8.     }
  9.     @Override
  10.     protected void convertHead(BaseViewHolder helper,final MySection item) {
  11.         helper.setText(R.id.header, item.header);
  12.         if(!item.isMroe)helper.setVisible(R.id.more,false);
  13.         else
  14.         helper.setOnClickListener(R.id.more, new View.OnClickListener() {
  15.             @Override
  16.             public void onClick(View v) {
  17.                 Toast.makeText(context,item.header+"more..",Toast.LENGTH_LONG).show();
  18.             }
  19.         });
  20.     }


「RecyclerView.Adapter优化了吗?」

「BaseRecyclerAdapter之添加动画」

「BaseRecyclerAdapter之添加不同布局(头部尾部)」

「BaseRecyclerAdapter之添加不同布局(优化篇)」

源码地址:传送门


参考:http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2016/0417/4154.html

0 0
原创粉丝点击