BaseRecyclerViewAdapterHelper的使用

一.配置

在 build.gradle 的 repositories 添加:

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

然后增加dependencies

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

二.使用

1,单类型BaseQuickAdapter使用

//这里的泛型:是你请求网络返回的Bean对象,这里模拟,就用String
public class TreasureFragmentAdapter extends BaseQuickAdapter<String>  {

   //构造方法, 第一个参数是你条目的布局Id,第二个是列表的数据集合
    public TreasureFragmentAdapter(int layoutResId, List data) {
        super(layoutResId, data);

    }

    @Override//参数一:原生的Holder ,参数二: 对应位置的数据
    protected void convert(BaseViewHolder baseViewHolder, String s) {
    //找到控件对象,进行强转,然后设置数据
        ((TextView) baseViewHolder.getView(R.id.tv)).setText(s);
        //这里是条目里边的子控件的点击事件
        baseViewHolder.setOnClickListener(R.id.tv,new OnItemChildClickListener()).setOnClickListener(R.id.tv,new OnItemChildClickListener());

    }

页面代码:
找控件

   this.recyclerView = (RecyclerView) view.findViewById(R.id.recyclerView);
  //模拟数据
        for (int i = 0; i < 100; i++) {
            arr.add(i + "");
        }
       //设置加载方式 
        recyclerView.setLayoutManager(new LinearLayoutManager(getActivity(), LinearLayoutManager.VERTICAL, false));
        //创建Adapter
        adapter = new TreasureFragmentAdapter(R.layout.image, arr);
        //设置Adapter
        recyclerView.setAdapter(adapter);

整个条目的点击事件

 //条目点击事件
        adapter.setOnRecyclerViewItemClickListener(new BaseQuickAdapter.OnRecyclerViewItemClickListener() {
            @Override
            public void onItemClick(View view, int i) {
        //adapter.getData().get(i)表示获取对应位置的数据   
                showToast(adapter.getData().get(i)+"条目被点击");
            }
        });
//条目里边控件的点击事件

adapter.setOnRecyclerViewItemChildClickListener(new BaseQuickAdapter.OnRecyclerViewItemChildClickListener() {
            @Override
            public void onItemChildClick(BaseQuickAdapter baseQuickAdapter, View view, int i) {



                showToast(adapter.getData().get(i)+"条目里边控件被点击");

            }
        });

注意: 条目点击和条目里边的控件点击不会有冲突

长按事件雷同上边的点击事件

添加动画

        adapter.openLoadAnimation();
**系统默认的5种动画如下:**

public static final int ALPHAIN = 1;    
 public static final int SCALEIN = 2;    
 public static final int SLIDEIN_BOTTOM = 3;    
 public static final int SLIDEIN_LEFT = 4;    
 public static final int SLIDEIN_RIGHT = 5;  

添加头和脚View

adapter.addHeaderView(View.inflate(getActivity(),R.layout.image,null));
        adapter.addHeaderView(View.inflate(getActivity(),R.layout.image,null));
        adapter.addHeaderView(View.inflate(getActivity(),R.layout.image,null));
        adapter.addHeaderView(View.inflate(getActivity(),R.layout.image,null));
        adapter.addFooterView(View.inflate(getActivity(),R.layout.image,null));
        adapter.addFooterView(View.inflate(getActivity(),R.layout.image,null));
        adapter.addFooterView(View.inflate(getActivity(),R.layout.image,null));

**注意:支持添加多个头和脚,位置会根据你天机头的多少进行调整,你什么都不需要做
且头部的处理也是在对应的页面上进行使用**

下拉刷新和上拉加载更多
上拉刷新可以使用Spring进行动画的自定义,效果更炫

加载更多可以使用Adapter用户体验更好

加载更多代码:

   //打开加载更多开关
        adapter.openLoadMore(arr.size(),true);

//加载更多回调
adapter.setOnLoadMoreListener(new BaseQuickAdapter.RequestLoadMoreListener() {
            @Override
            public void onLoadMoreRequested() {



        //不用post设置加载数据会报错,至于为什么会报错,还是不确定,这里边全是主线程   
                recyclerView.post(new Runnable() {
                    @Override
                    public void run() {
                        adapter.notifyDataChangedAfterLoadMore(arr2,false);

                    }
                });


            }
        });

侧滑的Adapter

传送门

你可能感兴趣的:(BaseRecyclerViewAdapterHelper的使用)