整合大量开源库项目(七)ListView迁移成 RecyclerView

简介:

转载请注明出处:王亟亟的大牛之路

开场先介绍下为什么使用RecyclerView,以及一些简单的理论知识

Q:为什么使用RecyclerView?
A: 一个非常灵活的用于在有限的窗口范围内显示大量数据的控件。

Q:使用RecyclerView的好处是什么?
A:提供了一种插拔式的体验,高度的解耦,异常的灵活

Q:RecyclerView可以实现什么?
A:ListView、GridView、瀑布效果等等等,并且性能优异!

OK,理论知识大致的介绍到这里,更多内容我们在代码中实现。

上一篇文章,我们是用一个CodeAdapter extends BaseAdapter来实现我们的适配器,而RecyclerView是另一种不同的实现,代码如下。

public class CodeActivity extends Son {
    private RecyclerView mRecyclerView;
    private RecyclerView.LayoutManager mLayoutManager;
    private CodeAdapter adapter;

    ToastUtils toastUtils;
    LogicJumpTo logicJumpTo;

    @Override
    public int getLayout() {
        LogUtils.d("--->CodeActivity getLayout");
        return R.layout.activity_code;
    }

    @Override
    public void init() {
        toastUtils = ToastUtils.getInstance();
        logicJumpTo = LogicJumpTo.getInstance();

        //创建默认的线性LayoutManager
        mLayoutManager = new LinearLayoutManager(this);
        mRecyclerView.setLayoutManager(mLayoutManager);
        //如果可以确定每个item的高度是固定的,设置这个选项可以提高性能
        mRecyclerView.setHasFixedSize(true);
        adapter = new CodeAdapter(getResources().getStringArray(R.array.codeArray));
        mRecyclerView.setAdapter(adapter);
        adapter.setOnItemClickListener(new CodeAdapter.OnRecyclerViewItemClickListener() {
            @Override
            public void onItemClick(View view, String data) {
                toastUtils.show(CodeActivity.this, data, false);
                switch (data) {
                    case "For EditText":
                        logicJumpTo.noValueJump(CodeActivity.this, EditTextActivity.class);
                        break;
                    case "For TextView":
                        break;
                    case "For Button/CheckBox/Switch/ProgressBar/Spinner":
                        break;
                    case "For ListView/GridView/TabHost":
                        break;
                    case "For Dialog":
                        break;
                    case "For CustomView":
                        break;
                    case "For ImageView":
                        break;
                    case "For WebView":
                        break;
                    case "For Animation":
                        break;
                    case "For Layout":
                        break;
                    case "For Menu":
                        break;
                    case "For NetWork":
                        break;
                    case "Others":
                        break;

                }
            }
        });
    }

    @Override
    public void bindID() {
        ActionBar actionBar = getActionBar();
        actionBar.setTitle("个人开发");
        actionBar.setDisplayHomeAsUpEnabled(true);

        mRecyclerView = (RecyclerView) findViewById(R.id.codeListView);

    }

    @Override
    public void setOnclick() {

    }

    @Override
    public void logic() {
        LogUtils.d("--->CodeActivity logic");

    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch (item.getItemId()) {
            case android.R.id.home:
                finish();
                return true;
        }
        return super.onOptionsItemSelected(item);
    }

    public static class CodeAdapter extends RecyclerView.Adapter<CodeAdapter.ViewHolder> implements OnClickListener{

        public String[] datas = null;

        public CodeAdapter(String[] datas) {
            this.datas = datas;
        }

        public static interface OnRecyclerViewItemClickListener {
            void onItemClick(View view, String data);
        }

        private OnRecyclerViewItemClickListener mOnItemClickListener = null;

        public void setOnItemClickListener(OnRecyclerViewItemClickListener listener) {
            this.mOnItemClickListener = listener;
        }

        //创建新View,被LayoutManager所调用
        @Override
        public ViewHolder onCreateViewHolder(ViewGroup viewGroup, int viewType) {
            View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.code_listview_item, viewGroup, false);
            ViewHolder vh = new ViewHolder(view);
            //将创建的View注册点击事件
            view.setOnClickListener(this);
            return vh;
        }

        //将数据与界面进行绑定的操作
        @Override
        public void onBindViewHolder(ViewHolder viewHolder, int position) {
            viewHolder.mTextView.setText(datas[position]);
            //将数据保存在itemView的Tag中,以便点击时进行获取
            viewHolder.itemView.setTag(datas[position]);
        }

        //获取数据的数量
        @Override
        public int getItemCount() {
            return datas.length;
        }

        @Override
        public void onClick(View v) {
            if (mOnItemClickListener != null) {
                //注意这里使用getTag方法获取数据
                mOnItemClickListener.onItemClick(v,(String)v.getTag());
            }

        }

        //自定义的ViewHolder,持有每个Item的的所有界面元素
        public class ViewHolder extends RecyclerView.ViewHolder {
            public TextView mTextView;

            public ViewHolder(View view) {
                super(view);
                mTextView = (TextView) view.findViewById(R.id.codeText);
            }
        }
    }

}


以上就是所有的Java代码层面的内容,下面会一点点来解释。

首先,说明一下!

RecyclerView是没有本身写好的 OnItemClickListener ()这样的回调的,得自己写!!

Item之间的间距啊,差异性什么的都可以存在,但是要用ItemDecoration 自己写!!

要让他变成ListView,GridView需要用LayoutManager这里倒不用自己写了!!


布局跟ListView类似,而且我们之前的ListView的动画也能沿用至此

 <android.support.v7.widget.RecyclerView
        android:id="@+id/codeListView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:choiceMode="singleChoice"
        android:scrollbars="none"
        android:layoutAnimation="@anim/code_item_anim" />

findViewById啊设置什么的都不多说,主要 点一下CodeAdapter 这一部分。

跟ListView一样,需要设置RecyclerView的Adapter,但是这里的Adapter跟ListView使用的Adapter不一样,这里的Adapter需要继承RecyclerView.Adapter,需要实现3个方法:

  - onCreateViewHolder()

  - onBindViewHolder()

  - getItemCount()

之前的一些ArrayAdapter,BaseAdapter的就不要在这里使用了,统一使用RecyclerView.Adapter。

public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup viewGroup, int i)

这个方法主要生成为每个Item inflater出一个View,但是该方法返回的是一个ViewHolder。方法是把View直接封装在ViewHolder中,然后我们面向的是ViewHolder这个实例,当然这个ViewHolder需要我们自己去编写。直接省去了当初的convertView.setTag(holder)和convertView.getTag()这些繁琐的步骤。

public void onBindViewHolder(RecyclerView.ViewHolder viewHolder, int i)
这个方法主要用于适配渲染数据到View中。方法提供给你了一个viewHolder,而不是原来的convertView。

然后就是我们的点击实现,首先这边我们创建一个借口,然后去实现这个接口。再在我们的主Activity中去setOnItemClickListener,使之成为有效的回路,来完成我们的业务逻辑。

源码地址:https://github.com/ddwhan0123/SoyiGit

事例APK:https://github.com/ddwhan0123/SoyiGit/blob/master/Soyi/Soyi.apk

记得点个赞哦!

这里写图片描述

目录
相关文章
|
11月前
|
XML Java Android开发
Android优化版ListView(附源代码)
本文是博主对Adapter(适配器)的一些理解,为了加深对Adapter的理解以及记录自己的阶段学习而写,同时也适合初学者阅读,参考本条博客的逻辑进行学习。
115 0
|
XML 缓存 算法
一个全新的RecyclerView Adapter框架源码开源
一个全新的RecyclerView Adapter框架源码开源
218 0
一个全新的RecyclerView Adapter框架源码开源
|
XML 缓存 Android开发
LayoutInflater 布局渲染工具原理分析
LayoutInflater 布局渲染工具原理分析
88 0
LayoutInflater 布局渲染工具原理分析
|
缓存 Android开发
聊聊RecyclerView新出的ConcatAdapter如何使用
聊聊RecyclerView新出的ConcatAdapter如何使用
聊聊RecyclerView新出的ConcatAdapter如何使用
【Flutter】ListView 列表高级功能 ( ScrollController 上拉加载更多 )
【Flutter】ListView 列表高级功能 ( ScrollController 上拉加载更多 )
508 0
【Flutter】ListView 列表高级功能 ( ScrollController 上拉加载更多 )
【Flutter】ListView 列表高级功能 ( RefreshIndicator 下拉刷新组件 )
【Flutter】ListView 列表高级功能 ( RefreshIndicator 下拉刷新组件 )
381 0
【Flutter】ListView 列表高级功能 ( RefreshIndicator 下拉刷新组件 )
flutter 实现不可滚动的ListView构建器
我试图在这里实现一个不可滚动的ListView构建器,但似乎找不到解决方法。原因是因为我希望所有内容都是可滚动的,并且我不想在可滚动的父级中拥有可滚动的小部件。
185 0
|
Java 容器
【RecyclerView】二、RecyclerView 简介 ( RecyclerView 特点 | RecyclerView 涉及到的类 )
【RecyclerView】二、RecyclerView 简介 ( RecyclerView 特点 | RecyclerView 涉及到的类 )
160 0
|
Java
【RecyclerView】 一、RecyclerView 最基本用法 ( 添加支持库 | 设置布局文件 | 自定义适配器 )
【RecyclerView】 一、RecyclerView 最基本用法 ( 添加支持库 | 设置布局文件 | 自定义适配器 )
670 0
【RecyclerView】 一、RecyclerView 最基本用法 ( 添加支持库 | 设置布局文件 | 自定义适配器 )
|
开发框架 缓存 容器
跨平台APP开发Flutter ListView 局部刷新数据、ListView点赞收藏
本文章实现的是 ListView 中 Item 局部数据刷新的效果,在这只是一个 Demo ,是一个实现思路,在应用开发的更多场景中如 资讯列表的点赞、收藏等等,诸多业务场景都可使用。
跨平台APP开发Flutter ListView 局部刷新数据、ListView点赞收藏