1024程序节|Android框架之一 BRVAH【BaseRecyclerViewAdapterHelper】使用demo

简介: BRVAH是一个强大的RecyclerAdapter框架(什么是RecyclerView?),它能节约开发者大量的开发时间,集成了大部分列表常用需求解决方案。为什么会有它?请查看「Android开源框架BRVAH由来篇」该框架于2016年4月10号发布的第1个版本到现在已经一年多了,经历了800多次代码提交,140多次版本打包,修复了1000多个问题,获得了9000多star,非常感谢大家的使用以及反馈。

文章目录

🍓🍓BRVAH 上部

🍄🍓动态图结果展示

🍄🍄myAdapter.java【第一个布局适配器】

🍄🍄youAdapter.java【第二个布局适配器】

🍄🍄MainActivity.java【主活动】

🍄🍄Person.java【Person对象类】

🍄🍄Pictures.java【Picture对象类】

🍓🍓BRVAH 下部

🍎🍎自定义动画

🍎🍎空布局

🍎🍎头部

🍎🍎头部

BRVAH是一个强大的RecyclerAdapter框架(什么是RecyclerView?),它能节约开发者大量的开发时间,集成了大部分列表常用需求解决方案。为什么会有它?请查看「Android开源框架BRVAH由来篇」该框架于2016年4月10号发布的第1个版本到现在已经一年多了,经历了800多次代码提交,140多次版本打包,修复了1000多个问题,获得了9000多star,非常感谢大家的使用以及反馈。

本篇为BRVAH的使用指南以及包含常见问题会第一时间更新最新的使用方法。最新版本请查看releases,由于持续更新。


下面我们就来看看这个开源框架的使用吧



🍓🍓BRVAH 上部

🍄🍓动态图结果展示


03c481bf2a40c10cd10649940e5ae7bb_7b0bedc4441e4943b049131178ec1817.gif

🍄🍄myAdapter.java【第一个布局适配器】

package com.example.Adapter;
import com.chad.library.adapter.base.BaseQuickAdapter;
import com.chad.library.adapter.base.viewholder.BaseViewHolder;
import com.example.brvhrecycleviewadapter.R;
import com.example.domain.Person;
import com.example.domain.Pictures;
import org.jetbrains.annotations.NotNull;
import java.util.List;
public class myAdapter extends BaseQuickAdapter<Person, BaseViewHolder> {
    public myAdapter(int layoutResId, List<Person> data) {
        super(layoutResId,data);
    }
    @Override
    protected void convert(@NotNull BaseViewHolder baseViewHolder, Person person) {
        // 链式
        //可链式调用赋值
        baseViewHolder.setText(R.id.textView, "第"+ person.getId() + "条数据")
                .setText(R.id.name2, person.getName())
//                .addOnClickListener(R.id.button)//给按钮添加点击事件
                .setImageResource(R.id.imageView,R.drawable.cm);
    }
}


注意

ccc9799e0789d2556c3c0c4d11f73769_983fc15fce3f43a297478960517e52d7.png

这是错误写法,对于布局中的的那个item对象的子控件监听这种方法已经被干掉了,新的方法需要在主活动MainActivity.class中注册。

例如: adapter2.addChildClickViewIds(R.id.img,R.id.tV);

注册布局中item对象里面的img控件和tV控件


🍄🍄youAdapter.java【第二个布局适配器】

package com.example.Adapter;
import com.chad.library.adapter.base.BaseQuickAdapter;
import com.chad.library.adapter.base.viewholder.BaseViewHolder;
import com.example.brvhrecycleviewadapter.R;
import com.example.domain.Pictures;
import org.jetbrains.annotations.NotNull;
import java.util.List;
public class youAdapter extends BaseQuickAdapter<Pictures, BaseViewHolder> {
    public youAdapter(int layoutResId, List<Pictures> pictureData) {
        super(layoutResId,pictureData);
    }
    @Override
    protected void convert(@NotNull BaseViewHolder baseViewHolder, Pictures pictures) {
        baseViewHolder
                .setText(R.id.tV,pictures.getName())
                .setBackgroundResource(R.id.img,pictures.getId());
    }
}

🍄🍄MainActivity.java【主活动】

package com.example.brvhrecycleviewadapter;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.GridLayoutManager;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import android.animation.Animator;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast;
import com.chad.library.adapter.base.BaseQuickAdapter;
import com.chad.library.adapter.base.animation.AlphaInAnimation;
import com.chad.library.adapter.base.animation.BaseAnimation;
import com.chad.library.adapter.base.listener.OnItemChildClickListener;
import com.chad.library.adapter.base.listener.OnItemClickListener;
import com.chad.library.adapter.base.listener.OnItemLongClickListener;
import com.example.Adapter.myAdapter;
import com.example.Adapter.youAdapter;
import com.example.domain.Person;
import com.example.domain.Pictures;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.TestOnly;
import java.lang.reflect.Array;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
    private RecyclerView recyclerView,recyclerView2;
    private List<Person> datas;
    //    private List<Pictures> pictures;
    private List<Pictures> pictureData;
    private myAdapter adapter;
    private youAdapter adapter2;
    private int[] PictureId;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        recyclerView = findViewById(R.id.RecyclerView);//实例化
        recyclerView2=findViewById(R.id.Recycle2);
        PictureId = new int[]{R.drawable.cm, R.drawable.cz, R.drawable.mht, R.drawable.nyg,
                R.drawable.pg, R.drawable.pt, R.drawable.sl, R.drawable.yt,R.drawable.cm,
                R.drawable.cz, R.drawable.mht, R.drawable.nyg,R.drawable.pg, R.drawable.pt,
                R.drawable.sl, R.drawable.yt};
        pictureData = new ArrayList<>();
        Pictures pictures;
        for (int i = 0; i < 16; i++) {
            pictures=new Pictures();
            pictures.setId(PictureId[i]);
            pictures.setName("第"+i+"个");
            pictureData.add(pictures);
        }
        //模拟数据
        datas = new ArrayList<>();
        Person person;
        for (int i = 0; i < 8; i++) {
            person = new Person();
            person.setId(i);
            person.setName("第" + i + "条内容");
            datas.add(person);
        }
        //todo 创建布局管理【必有】
        LinearLayoutManager layoutManager = new LinearLayoutManager(this);
        layoutManager.setOrientation(LinearLayoutManager.VERTICAL);
        recyclerView.setLayoutManager(layoutManager);
        GridLayoutManager  gridLayoutManager=new GridLayoutManager(this,4);
        recyclerView2.setLayoutManager(gridLayoutManager);
//        GridLayoutManager gridLayoutManager=new GridLayoutManager(this,4);
//        recyclerView.setLayoutManager(gridLayoutManager);
        //创建适配器
        adapter = new myAdapter(R.layout.item, datas);
        adapter2=new youAdapter(R.layout.grid_item,pictureData);
//        adapter2.setAdapterAnimation(new BaseAnimation() {
//            @NotNull
//            @Override
//            public Animator[] animators(@NotNull View view) {
//                return new Animator[0];
//            }
//        });
        // 注册子控件点击事件的  button控件按钮
        adapter.addChildClickViewIds(R.id.button);
        adapter2.addChildClickViewIds(R.id.img,R.id.tV);
        // item 点击监听
        adapter.setOnItemClickListener(new OnItemClickListener() {
            @Override
            public void onItemClick(@NonNull @NotNull BaseQuickAdapter<?, ?> adapter, @NonNull @NotNull View view, int position) {
                Toast.makeText(MainActivity.this, "你点击了第" + (position + 1) + "条信息", Toast.LENGTH_SHORT).show();
            }
        });
        // item长按监听
        adapter.setOnItemLongClickListener(new OnItemLongClickListener() {
            @Override
            public boolean onItemLongClick(@NonNull @NotNull BaseQuickAdapter adapter, @NonNull @NotNull View view, int position) {
                Toast.makeText(MainActivity.this, "你长按了第" + (position + 1) + "条信息", Toast.LENGTH_SHORT).show();
                return false;
            }
        });
        // Listview 中item的点击事件监听
        adapter.setOnItemChildClickListener(new OnItemChildClickListener() {
            @Override
            public void onItemChildClick(@NonNull @NotNull BaseQuickAdapter adapter, @NonNull @NotNull View view, int position) {
                Toast.makeText(MainActivity.this, "你点击了" + (position + 1) + "button按钮", Toast.LENGTH_SHORT).show();
            }
        });
        // 两个   adapter2 事件
        adapter2.setOnItemChildClickListener(new OnItemChildClickListener() {
            @Override
            public void onItemChildClick(@NonNull @NotNull BaseQuickAdapter adapter, @NonNull @NotNull View view, int position) {
                switch (view.getId()){
                    case R.id.img:
                        Toast.makeText(MainActivity.this,"你点击了"+(position+1)+"图片",Toast.LENGTH_SHORT).show();
                        break;
                    case R.id.tV:
                        Toast.makeText(MainActivity.this,"你点击了"+(position+1)+"文字",Toast.LENGTH_SHORT).show();
                        break;
                }
            }
        });
        //给RecyclerView设置适配器
        recyclerView.setAdapter(adapter);
        recyclerView2.setAdapter(adapter2);
        adapter.notifyDataSetChanged();
    }
}

🍄🍄Person.java【Person对象类】

package com.example.domain;
public class Person {
    public int id;
    public String name;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
}

🍄🍄Pictures.java【Picture对象类】

package com.example.domain;
public class Pictures {
    int id;
    String name;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
}

🍓🍓BRVAH 下部

🍎🍎自定义动画

效果图》》》


// 第二个布局添加自定义动画
        adapter2.setAdapterAnimation(new BaseAnimation() {
            @NotNull
            @Override
            public Animator[] animators(@NotNull View view) {
                return new Animator[]{
                        ObjectAnimator.ofFloat(view, "scaleY", 1, 0.1f, 1),
                        ObjectAnimator.ofFloat(view, "scaleX", 1, 0.1f, 1)
                };
            }
        });

默认执行一次,想要反复执行可以自行设置。记得这段要添加在MainActivity.java的adapter2 new出来之后,setAdapter之前

空余时间别忘记了看看源码~~~


aac519a7a511379cf21c9ed26aef7511_0f76fb04ec8b4a04bd37a93263c8f3d1.png

🍎🍎空布局

说明:当adapter中数据不为空时,空布局不会生效


通过设置View为空布局

代码如下:


View view = ...
adapter.setEmptyView(view);


通过设置LayoutResId为空布局

代码如下:


adapter.setEmptyView(R.layout.loading_view);

设置是否使用空布局(默认为true)

代码如下:


// java
adapter.setUseEmpty(false);
// kotlin
adapter.isUseEmpty = false


🍎🍎头部

说明:此头部并不是item的头部,而是整个Adapter的头部

代码如下:


View view = ...;
adapter.addHeaderView(view);
// 指定添加位置
adapter.addHeaderView(view, 1);
// 替换头部
adapter.setHeaderView(view);
//替换指定位置头部
adapter.setHeaderView(view, 0);
// 移除头部
adapter.removeHeaderView(view);
// 移除全部头部
adapter.removeAllHeaderView();

🍎🍎头部

说明:此脚部不是item的脚部,而是整个Adapter的

代码如下:


View view = ...;
adapter.addFooterView(view);
// 指定添加位置
adapter.addFooterView(view, 1);
// 替换脚部
adapter.setFooterView(view);
//替换指定位置脚部
adapter.setFooterView(view, 0);
// 移除脚部
adapter.removeFooterView(view);
// 移除全部脚部
adapter.removeAllFooterView();


是不是还是不太尽兴,那就来看看Github的详细解释吧。

BaseRecyclerViewAdapterHelper 使用详情页


BaseQuickAdapter主要属性、方法说明


空 Java Kotlin 说明

获取Context getContext() 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 id addChildClickViewIds() 同java 添加以后,setOnItemChildClickListener才会响应

添加需要响应长按事件的子View id getChildLongClickViewIds() 同java

动画  

是否打开动画 setAnimationEnable() animationEnable 默认:false

动画是否仅第一次执行 setAnimationFirstOnly() isAnimationFirstOnly

设置自定义动画 setAdapterAnimation() adapterAnimation

设置使用内置默认动画 setAnimationWithDefault() setAnimationWithDefault() 参数为枚举

觉得有用的可以给个三连,关注一波!!!带你了解更多的Android框架

目录
相关文章
|
2月前
|
XML API Android开发
码农之重学安卓:利用androidx.preference 快速创建一、二级设置菜单(demo)
本文介绍了如何使用androidx.preference库快速创建具有一级和二级菜单的Android设置界面的步骤和示例代码。
50 1
码农之重学安卓:利用androidx.preference 快速创建一、二级设置菜单(demo)
|
2月前
|
物联网 区块链 vr&ar
未来已来:探索区块链、物联网与虚拟现实技术的融合与应用安卓与iOS开发中的跨平台框架选择
【8月更文挑战第30天】在科技的巨轮下,新技术不断涌现,引领着社会进步。本文将聚焦于当前最前沿的技术——区块链、物联网和虚拟现实,探讨它们各自的发展趋势及其在未来可能的应用场景。我们将从这些技术的基本定义出发,逐步深入到它们的相互作用和集成应用,最后展望它们如何共同塑造一个全新的数字生态系统。
|
3月前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台框架解析
在移动应用开发的广阔舞台上,安卓和iOS一直是两大主角。随着技术的进步,开发者们渴望能有一种方式,让他们的应用能同时在这两大平台上运行,而不必为每一个平台单独编写代码。这就是跨平台框架诞生的背景。本文将探讨几种流行的跨平台框架,包括它们的优势、局限性,以及如何根据项目需求选择合适的框架。我们将从技术的深度和广度两个维度,对这些框架进行比较分析,旨在为开发者提供一个清晰的指南,帮助他们在安卓和iOS的开发旅程中,做出明智的选择。
|
4天前
|
Java Maven 开发工具
第一个安卓项目 | 中国象棋demo学习
本文是作者关于其第一个安卓项目——中国象棋demo的学习记录,展示了demo的运行结果、爬坑记录以及参考资料,包括解决Android Studio和maven相关问题的方法。
第一个安卓项目 | 中国象棋demo学习
|
15天前
|
前端开发 Java 数据库
💡Android开发者必看!掌握这5大框架,轻松打造爆款应用不是梦!🏆
在Android开发领域,框架犹如指路明灯,助力开发者加速应用开发并提升品质。本文将介绍五大必备框架:Retrofit简化网络请求,Room优化数据库访问,MVVM架构提高代码可维护性,Dagger 2管理依赖注入,Jetpack Compose革新UI开发。掌握这些框架,助你在竞争激烈的市场中脱颖而出,打造爆款应用。
80 3
|
23天前
|
编译器 Android开发 开发者
带你了解Android Jetpack库中的依赖注入框架:Hilt
本文介绍了Hilt,这是Google为Android开发的依赖注入框架,基于Dagger构建,旨在简化依赖注入过程。Hilt通过自动化的组件和注解减少了DI的样板代码,提高了应用的可测试性和可维护性。文章详细讲解了Hilt的主要概念、基本用法及原理,帮助开发者更好地理解和应用Hilt。
40 8
|
2月前
|
设计模式 Java Android开发
探索安卓应用开发:从新手到专家的旅程探索iOS开发中的SwiftUI框架
【8月更文挑战第29天】本文旨在通过一个易于理解的旅程比喻,带领读者深入探讨安卓应用开发的各个方面。我们将从基础概念入手,逐步过渡到高级技术,最后讨论如何维护和推广你的应用。无论你是编程新手还是有经验的开发者,这篇文章都将为你提供有价值的见解和实用的代码示例。让我们一起开始这段激动人心的旅程吧!
|
2月前
|
Android开发
基于Amlogic 安卓9.0, 驱动简说(三):使用misc框架,让驱动更简单
如何使用Amlogic T972安卓9.0系统上的misc框架来简化驱动程序开发,通过misc框架自动分配设备号并创建设备文件,从而减少代码量并避免设备号冲突。
24 0
基于Amlogic 安卓9.0, 驱动简说(三):使用misc框架,让驱动更简单
|
2月前
|
存储 前端开发 Java
Android MVVM框架详解与应用
在Android开发中,随着应用复杂度的增加,如何有效地组织和管理代码成为了一个重要的问题。MVVM(Model-View-ViewModel)架构模式因其清晰的结构和高效的开发效率,逐渐成为Android开发者们青睐的架构模式之一。本文将详细介绍Android MVVM框架的基本概念、优势、实现流程以及一个实际案例。
|
3月前
|
前端开发 安全 数据库
💡Android开发者必看!掌握这5大框架,轻松打造爆款应用不是梦!🏆
【7月更文挑战第28天】在Android开发领域,五大框架如星辰般指引方向,加速进程,提升应用品质。1. **Retrofit**:Square公司的类型安全HTTP客户端,使网络请求变得优雅简洁。2. **Room**:Google推荐的ORM库,简化SQLite数据库访问。3. **MVVM**:一种架构模式,提高代码可维护性和扩展性。4. **Dagger 2**:依赖注入框架,减少样板代码,以声明方式管理依赖。5. **Jetpack Compose**:全新的UI工具包,采用声明式UI编程,让UI开发更直观高效。掌握这些框架,能有效应对Android开发挑战,助力打造爆款应用。
215 0
下一篇
无影云桌面