Android适配器EasyRecyclerViewAdapte

作者: kaxi4it | 来源:发表于2016-12-21 17:02 被阅读0次

    前言


    网上的RecyclerView通用适配器都已完善的很好了,而我只是在原有的基础上,添砖加瓦罢了
    我所发布的EasyRecyclerViewAdapter是基于zhy大神的base-adapter所修改而成
    并已完全剥离了对Listview的适配器支持,只支持RecyclerView
    最主要的修改部分为zhy大神的adapter默认绑定了item的单击和长按时间,并且设置点击事件时,必须直接绑定相应listener,而我将item的默认绑定事件取消了,如果需要设置item相关事件时,只需要直接绑定viewId即可
    最近参考了下cym大神的adapter,把item的加载动画部分也收罗了进来
    最后因为比较钟情于用户无感知的自动加载更多的方式,所以又添加了一个新的AutoLoadMoreAdapter

    一 效果图


    暂时并没有效果图 看zhy的效果图就是了 回头补一个,高冷的我就是不补图

    二 使用方法


    最新版本号最新版本号

    在你root的gradle中添加引用

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

    然后在module的gradle中添加引用

    dependencies {
        compile 'com.github.kaxi4it:EasyRecyclerViewAdapter:1.9'
    }
    
    CommonAdapter的使用

    由于是基于zhy的base-adapter所修改,所以使用方式和zhy的demo是一致的,唯一的区别是点击事件的绑定方法,需要如下操作:

    mAdapter = new CommonAdapter<String>(this, R.layout.item_list, mDatas){
        @Override
        protected void convert(ViewHolder holder, String s, int position)    {
            holder.setText(R.id.id_item_list_title, "text");
            //绑定单击,长按,触摸,开关事件
            holder.setOnItemChildClickListener(R.id.id_item_list_title);
            holder.setOnItemChildLongClickListener(R.id.id_item_list_title);
            holder.setOnItemChildTouchListener(R.id.id_item_list_title);
            holder.setOnItemChildCheckChangeListener(R.id.id_item_list_title);
        }
    };
    

    将相应的事件绑定在对应viewId后,可在您所需要的地方通过adapter的相关方法来使用:

    //单击事件
    mAdapter.setEasyOnItemChildClickListener(new EasyOnItemChildClickListener(){
        @Override
        public void onClick(View view, int position) {
            switch(view.getId()){
                case R.id.id_item_list_title:
                    // do sth
                break;
            }
        }
    });
    
    //长按事件
    mAdapter.setEasyOnItemChildLongClickListener(new EasyOnItemChildLongClickListener() {
        @Override
        public boolean onLongClick(View view, int position) {
            return false;
        }
    });
    
    //触摸事件
    mAdapter.setEasyOnItemChildTouchListener(new EasyOnItemChildTouchListener() {
        @Override
        public boolean onTouch(View v, MotionEvent event, int position) {
            return false;
        }
    });
    
    //开关事件
    mAdapter.setEasyOnItemChildCheckChangeListener(new EasyOnItemChildCheckChangeListener() {
        @Override
        public void onCheckedChanged(CompoundButton childView, int position, boolean isChecked) {
            // do sth
        }
    });
    

    关于动画部分借鉴的cym的代码部分和使用方式,其中分为ALPHAIN, SCALEIN, SLIDEIN_BOTTOM, SLIDEIN_LEFT, SLIDEIN_RIGHT 五种动画方式,淡入动画,缩放动画,底部滑入,左侧滑入,右侧滑入,可自行选择,isFirstOnly()是设置动画是否只在第一次显示item时有效,默认为true

    //动画效果
    mAdapter.openLoadAnimation(MultiItemTypeAdapter.SCALEIN);
    //是否只在第一次显示时有效
    mAdapter.isFirstOnly(false);
    
    AutoLoadMoreAdapter的使用

    AutoLoadMoreAdapter的使用方式,延续了CommonAdapter的风格,默认添加了一个loadMore的回调方法来实现自动加载更多的逻辑部分:

    mAdapter = new AutoLoadMoreAdapter<String>(this, R.layout.item_list, mDatas)
            {
                @Override
                protected void convert(ViewHolder holder, String s, int position)
                {
                    holder.setText(R.id.id_item_list_title, s);
                    holder.setOnItemChildClickListener(R.id.id_item_list_title);
                }
    
                @Override
                protected void loadMore() {
                    //调用加载更多的网络请求
                    Toast.makeText(RecyclerViewActivity.this,"加载更多",Toast.LENGTH_SHORT).show();
                }
            };
    

    当遇到网络请求加载更多出现异常等失败的情况下,默认情况下是不会再调用自动加载更多的方法,那么此时需要用户手动重置恢复自动加载更多的回调:

    mAdapter.resetLoadMoreState();
    

    开放了用户自定义加载更多的提前量,默认设置为4,大于0会提前加载、等于0仅在最后一条加载更多,小于0则关闭了自动加载更多:

    mAdapter.setAdvanceCount();
    

    三 最终章


    按照如上方式正确操作后,就可以使用EasyRecyclerViewAdapter了
    项目完整代码在 https://github.com/kaxi4it/EasyRecyclerViewAdapter 中可查看

    相关文章

      网友评论

        本文标题:Android适配器EasyRecyclerViewAdapte

        本文链接:https://www.haomeiwen.com/subject/bgyqvttx.html