Android 笔记 RecyclerView的简单使用

RecyclerView

创建列表与卡片
显示一列项目一般会使用基本的ListView或者GridView。后来在supper library里面增加了一个RecyclerView,里面封装了更全面的功能,官方教程更推荐使用这个新的显示列表项目的组件。

在一本书《Android编程权威教程》里面介绍RecycleView的时候是这么讲的。假如一个列表有100项,每个项目包括1个TextView,那我们岂不是要准备100个TextView?这样肯定会消耗大量资源。实际上,我们只需要准备刚好填满屏幕的数量就好。RecyclerView顾名思义,就是可以把子View重复使用,只创建适应屏幕的数量,重复使用,可以节约资源。

除此以外,RecycleView还提供了一些有用的功能,比如可以在动态增加删除资源的时候提供动画效果等。这些我还没有实践过,仅测试了显示功能。

开始使用

首先,需要在supper library里面添加RecyclerView,然后就可以像普通的View一样添加到Layout里面去了。

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/activity_test_recycle"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.septem.firstapp.TestRecycleActivity">

    <android.support.v7.widget.RecyclerView
        android:scrollbars="vertical"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/recycler_view_test"
        android:background="#70b0e7" />
</RelativeLayout>

然后在程序里添加

private void addViews() {
        mRecyclerView = (RecyclerView)findViewById(R.id.recycler_view_test);
        mLayoutManager = new GridLayoutManager(this,1);
        mRecyclerView.setLayoutManager(mLayoutManager);
        mAdapter = new MyRecyclerAdapter();
        mRecyclerView.setAdapter(mAdapter);
    }

正如上面所写,必须添加的项目包括
1,一个layoutManager,一般情况是gridLayoutManager或者LinearLayoutManager.
2,一个Adapter,用来添加数据

下面,需要定义一个MyRecyclerAdapter

private class MyRecyclerAdapter extends RecyclerView.Adapter<MyHolder> {

        @Override
        public MyHolder onCreateViewHolder(ViewGroup parent, int viewType) {
            ImageView iv = new ImageView(thisActivity);
            LinearLayout.LayoutParams ivLayoutParams =
                    new LinearLayout.LayoutParams(300,
                            300);
            ivLayoutParams.setMargins(5,5,0,0);
            iv.setLayoutParams(ivLayoutParams);
            iv.setBackgroundColor(Color.parseColor("#78daa8"));
            iv.setTextAlignment(View.TEXT_ALIGNMENT_CENTER);
            iv.setScaleType(ImageView.ScaleType.CENTER_CROP);
            //以上是代码定义一个ImageView,也可以用XML定义,然后添加,如下
            //View v = LayoutInflater.from(parent.getContext())
            //                   .inflate(R.layout.my_text_view, parent, false);
            MyHolder mHolder = new MyHolder(iv);
            return mHolder;
        }

        @Override
        public void onBindViewHolder(MyHolder holder, int position) {
            mCursor.moveToFirst();
            mCursor.move(position);
            holder.iv.setImageBitmap(null);
            LoadTask loadTask = new LoadTask();
            loadTask.execute(position);
        }

        @Override
        public int getItemCount() {
            return mCursor.getCount();
        }
    }

自定义一个Adapter最少需要重写3个方法,就是上面这3个
onCreateViewHolder获得一个viewHolder,是专门用于控制子View的,这里需要在合适的地方建立一个新的类

private class MyHolder extends RecyclerView.ViewHolder {
        public ImageView iv;

        public MyHolder(View v) {
            super(v);
            this.iv = (ImageView) v;
        }
    }

这样就可以创建一个最简单的ViewHolder。之前在onCreateViewHolder里面创建的子View被传递到这个里面来。

onBindViewHolder(MyHolder holder, int position)
用于在子View里面显示数据,而子View是从参数的holder里面找到的

getItemCount()用于获取子View的个数

在以上设置好以后,一个最简单的RecycleView就建立好了。

注意事项

一般会在一个单独的线程里面读取数据,然后显示出来,这时候,需要获得对应Position的子View
ImageView iv = (ImageView)mLayoutManager.findViewByPosition(position);

还有一个方法,getChildAt(index)也可以获得子View,但是实际测试中发现经常出现错误。总结出原因是,这个方法返回的是屏幕可见的View
比如,getChildAt(1)返回屏幕上第2个可见的View
而之前那个方法是我们需要的,就是返回整个列表中对应位置的View。这一点需要注意。
官网的文档里面居然没写清楚。

还有一个需要注意的,如果对应整个列表位置的View已经被移到屏幕外了,那么这个View会返回为null,如果这时候对其操作会出现NullPointer exception。所以,在操作的时候要判断一下

if(iv!=null)
    iv.setImageBitmap(bitmap);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值