Android框架BRVAH使用指南

BRVAH(BaseRecyclerViewAdapterHelper)是一个强大并且灵活的RecyclerViewAdapter,集成了大部分列表常用需求解决方案。

1、框架引入

将JitPack存储库添加到您的构建文件中(项目根目录下build.gradle文件)

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

在 build.gradle(Module:app) 的 dependencies 添加依赖项:

dependencies {
    implementation 'com.github.CymChad:BaseRecyclerViewAdapterHelper:3.0.10'
}

2、BaseQuickAdapter

  • BaseQuickAdapter<T, VH>为最基本的类型,提供最基础的功能,所有子类都继承于此。
  • T为数据类型;VHViewHolder类型,如果不需要自定义,直接使用BaseViewHolder即可。
  • 框架提供了一个基础BaseViewHolder,所有自定义的ViewHolder都应该继承于此!

2.1、快速使用

BaseQuickAdapter<T, VH>为最基础的类型,直接使用BaseQuickAdapter<T, VH>即可简单快速实现一个Adapter

public class DemoAdapter extends BaseQuickAdapter<String, BaseViewHolder> {

    /**
     * 构造方法,此示例中,在实例化Adapter时就传入了一个List。
     * 如果后期设置数据,不需要传入初始List,直接调用 super(layoutResId); 即可
     */
    public DemoAdapter(list List<String>) {
        super(R.layout.layout_demo, list);
    }

    /**
     * 在此方法中设置item数据
     */
    @Override
    protected void convert(@NotNull BaseViewHolder helper, @NotNull String item) {
        helper.setText(R.id.tweetName, "This is an Item, pos: " + (helper.getAdapterPosition() - getHeaderLayoutCount()));
    }
}

Activity中设置:

DemoAdapter adapter = new DemoAdapter(new ArrayList<String>());
mRecyclerView.setAdapter(adapter);
 
 // 设置新的数据方法
adapter.setNewData(list)

2.2、纯View创建Item 

如果不想使用xml布局,想直接使用View代码方式创建,那么构造函数使用super(0),并且在Adapter中重写onCreateDefViewHolder方法:

public class DemoAdapter extends BaseQuickAdapter<String, BaseViewHolder> {

    public DemoAdapter(list List<String>) {
      	//布局传递0
      	super(0);
    }
    
    /**
     * 重写此方法,自己创建 View 用来构建 ViewHolder
     */
    @NotNull
    @Override
    protected BaseViewHolder onCreateDefViewHolder(@NotNull ViewGroup parent, int viewType) {
      	// 创建自己的布局
        FrameLayout layout = new FrameLayout(getContext());
        ...
        ...
        return createBaseViewHolder(layout);
    }

    @Override
    protected void convert(@NotNull BaseViewHolder helper, @NotNull String item) {
      	...
    }
}

2.3、点击事件

Item 点击事件:

DemoAdapter adapter = new DemoAdapter();

// 设置点击事件
adapter.setOnItemClickListener(new OnItemClickListener() {
    @Override
    public void onItemClick(@NonNull BaseQuickAdapter adapter, @NonNull View view, int position) {
        Tips.show("onItemClick " + position);
    }
});

Item 长按事件:

adapter.setOnItemLongClickListener(new OnItemLongClickListener() {
    @Override
    public boolean onItemLongClick(@NonNull BaseQuickAdapter adapter, @NonNull View view, int position) {
        Tips.show("onItemLongClick " + position);
        return true;
    }
});

Item 内子View的点击事件:

注意,请不要在convert方法里注册控件id

// 先注册需要点击的子控件id(注意,请不要写在convert方法里)
adapter.addChildClickViewIds(R.id.btn, R.id.iv_num_add, R.id.item_click);
// 设置子控件点击监听
adapter.setOnItemChildClickListener(new OnItemChildClickListener() {
    @Override
    public void onItemChildClick(@NonNull BaseQuickAdapter adapter, @NonNull View view, int position) {
        if (view.getId() == R.id.btn) {
            Tips.show("onItemChildClick " + position);
        }
    }
});

Item 内子View的长按事件:

注意,请不要在convert方法里注册控件id

// 先注册需要长按的子控件id(注意,请不要写在convert方法里)
adapter.addChildLongClickViewIds(R.id.btn, R.id.iv_num_add, R.id.item_click);
// 设置子控件长按监听
adapter.setOnItemChildLongClickListener(new OnItemChildLongClickListener() {
    @Override
    public boolean onItemChildLongClick(@NonNull BaseQuickAdapter adapter, @NonNull View view, int position) {
        if (view.getId() == R.id.btn) {
           Tips.show("onItemChildLongClick " + position);
        }
        return true;
    }
});

2.4、BaseQuickAdapter主要属性、方法说明

JavaKotlin说明
获取ContextgetContext()context
数据相关
获取Adapter中数据getData()data只能get
设置新的数据实例setNewData()setNewData()将会替换List指针引用
添加数据addData()addData()
移除数据remove()remove()
改变某一位置的数据setData()setData()
替换整个数据replaceData()replaceData()不会更改原数据的引用
设置Diff数据(异步,推荐)setDiffCallback()setDiffCallback()配置数据差异化比较的Callback
setDiffConfig()setDiffConfig()更高程度的自定义化配置
setDiffNewData(List)setDiffNewData(List?)必须先设置setDiffCallback() 或者 setDiffConfig(),否则不生效
设置Diff数据setDiffNewData(DiffResult, List)setDiffNewData(DiffResult, List?)通过DiffResult设置数据,Adapter内部不关心Diff过程,只要结果。
空布局
设置空布局视图setEmptyView()setEmptyView()仅当 data 为空时,才会显示
是否有空视图hasEmptyView()hasEmptyView()
获取空视图getEmptyLayout()getEmptyLayout()
是否使用空布局setUseEmpty()isUseEmpty
头布局
添加头布局addHeaderView()addHeaderView()
设置头布局setHeaderView()setHeaderView()
是否有头布局hasHeaderLayout()hasHeaderLayout()
移除头布局removeHeaderView()removeHeaderView()
移除所有头布局removeAllHeaderView()removeAllHeaderView()
脚布局
添加脚布局addFooterView()addFooterView()
设置脚布局setFooterView()setFooterView()
是否有脚布局hasFooterLayout()hasFooterLayout()
移除脚布局removeFooterView()removeFooterView()
移除所有脚布局removeAllFooterView()removeAllFooterView()
布局其他属性
当显示空布局时,是否显示 头布局setHeaderWithEmptyEnable()headerWithEmptyEnable
当显示空布局时,是否显示 脚布局setFooterWithEmptyEnable()footerWithEmptyEnable
点击事件
item点击事件setOnItemClickListener()同java
item长按事件setOnItemLongClickListener同java
item子view的点击事件setOnItemChildClickListener同java
item子view的长按事件setOnItemChildLongClickListener同java
添加需要响应点击事件的子View idaddChildClickViewIds()同java添加以后,setOnItemChildClickListener才会响应
添加需要响应长按事件的子View idgetChildLongClickViewIds()同java
动画
是否打开动画setAnimationEnable()animationEnable默认:false
动画是否仅第一次执行setAnimationFirstOnly()isAnimationFirstOnly
设置自定义动画setAdapterAnimation()adapterAnimation
设置使用内置默认动画setAnimationWithDefault()setAnimationWithDefault()参数为枚举

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值