使用BaseRecyclerViewAdapterHelper

    xiaoxiao2021-04-16  35

    一个强大并且灵活的RecyclerViewAdapter

    它能做什么?

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

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

    添加item点击事件

    新增添加头部、添加尾部

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

    新增分组

    自定义item类型

    如何使用它?

    先在 build.gradle 的 repositories 添加:

        allprojects {        repositories {            ...            maven { url "https://jitpack.io" }        }    }

    然后在dependencies添加:

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

    如何使用它来创建Adapter?

    public class QuickAdapter extends BaseQuickAdapter<Status> {    public QuickAdapter(Context context) {        super(context, R.layout.tweet, DataServer.getSampleData());    }     @Override    protected void convert(BaseViewHolder helper, Status item) {        helper.setText(R.id.tweetName, item.getUserName())                .setText(R.id.tweetText, item.getText())                .setText(R.id.tweetDate, item.getCreatedAt())                .setImageUrl(R.id.tweetAvatar, item.getUserAvatar())                .setVisible(R.id.tweetRT, item.isRetweet())                .linkify(R.id.tweetText);    }}

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

    如何添加item点击事件?

    mQuickAdapter.setOnRecyclerViewItemClickListener(new BaseQuickAdapter.OnRecyclerViewItemClickListener() {            @Override            public void onItemClick(View view, int position) {                //..            }        });

    如何使用它添加动画?

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

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

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

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

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

    使用它添加头部添加尾部

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

    使用它加载更多

    mQuickAdapter.setOnLoadMoreListener(PAGE_SIZE, new BaseQuickAdapter.RequestLoadMoreListener() {            @Override            public void onLoadMoreRequested() {                if (mCurrentCounter >= TOTAL_COUNTER) {                    mRecyclerView.post(new Runnable() {                        @Override                        public void run() {                            mQuickAdapter.isNextLoad(false);                        }                    });                } else {                    // reqData                    mCurrentCounter = mQuickAdapter.getItemCount();                    mQuickAdapter.isNextLoad(true);                }            }        });

    使用分组

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

    自定义item类型

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

    「RecyclerView.Adapter优化了吗?」

    「BaseRecyclerAdapter之添加动画」

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

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

    源码地址: 传送门

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

    转载请注明原文地址: https://ju.6miu.com/read-672568.html

    最新回复(0)