RecyclerView的基本使用(一)


RecyclerView 使用之前需要导包,不然系统会不认识这个控件,引用是添加 app  module 的,如下:

dependencies {
    compile 'com.android.support:recyclerview-v7:25.2.0'
}

在 xml 文件中 添加控件:

<android.support.v7.widget.RecyclerView
    android:id="@+id/grid_recycler_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />

RecyclerView 的 layoutManager 有三种,

1. LinearLayoutManager ,实现 ListView 效果

2.GridLayoutManager,实现 GridView 效果

3.StaggeredGridLayoutManager ,自定义,可以实现瀑布流之类的


下面,先讲 RecyclerView 实现List View的效果


初始化RecyclerView:    

  @BindView(R.id.grid_recycler_view)
    RecyclerView mRecyclerView;
在activity 的 onCrate 方法中,设置 RecyclerView 的 基本设置

        mRecyclerView.setHasFixedSize(true);
        mRecyclerView.setLayoutManager(new LinearLayoutManager(this));
        mLinearAdapter = new LinearAdapter<>(this, mNames);
        mRecyclerView.setAdapter(mLinearAdapter);

RecyclerView 的adapter 要继承 RecyclerView.Adapter,LinearAdapter的代码如下:

public class LinearAdapter <T>extends RecyclerView.Adapter {

    protected Context mContext;
    protected View mLayoutView;
    protected List<T> mData;

    public LinearAdapter(Context context,List<T>data){
        this.mContext=context;
        this.mData=data;
    }

    @Override
    public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        //注:不可使用view=LayoutInflater.from(mContext).inflate(R.layout.item_layout,null);不然会报错
        mLayoutView= LayoutInflater.from(mContext).inflate(R.layout.item_layout,parent,false);
        ViewHolder viewHolder=new ViewHolder(mLayoutView);
        return viewHolder;
    }

    @Override
    public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
        String name=mData.get(position).toString();
        ((ViewHolder)holder).mTvName.setText(name);
    }

    @Override
    public int getItemCount() {
        return mData==null?0:mData.size();
    }

   class ViewHolder extends RecyclerView.ViewHolder{

        TextView mTvName;

        public ViewHolder(View view) {
            super(view);

            mTvName=(TextView)view.findViewById(R.id.tv_name);
        }


    }
}

RecyclerView 要实现gridView 的效果的话也很简单,adapter 可以不变,只需要将 LinearLayoutManager 换成  GridLayoutManager 即可,如 Activity中代码如下:

        mRecyclerView.setHasFixedSize(true);
        mRecyclerView.setLayoutManager(new GridLayoutManager(this,3));
        mLinearAdapter = new LinearAdapter<>(this, mNames);
        mRecyclerView.setAdapter(mLinearAdapter);

注:new GridLayoutManager(this,3) 中第一个参数是 Activity 或 Fragment 的实例,第二个参数表示 GridView 一行显示几个item。


RecyclerView 的点击事件:

虽然 RecyclerView 给我们提供了很好的自定义效果,但是每种不足的是,它不像ListView 和 GridView 一样 有 OnItemClick 的点击事件,那么就需要我们自己来实现它的 项点击和 长按事件了。

首先,需要在 adapter 中实现 onClick 的接口,将单个View的 点击和长按事件赋予给这个接口,在之前的 adapter 基础上做修改,代码如下:


package com.test;


import android.content.Context;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

import java.util.List;

import static android.icu.lang.UCharacter.GraphemeClusterBreak.T;

/**
 * Created by Admin on 2017/4/18.
 */

public class LinearAdapter <T>extends RecyclerView.Adapter {

    protected Context mContext;
    protected View mLayoutView;
    protected List<T> mData;

    protected OnRecyclerItemClickListener mOnRecyclerItemClickListener;

    public void setOnRecyclerItemClickListener(OnRecyclerItemClickListener onRecyclerItemClickListener){
        this.mOnRecyclerItemClickListener=onRecyclerItemClickListener;
    }

    public LinearAdapter(Context context,List<T>data){
        this.mContext=context;
        this.mData=data;
    }

    @Override
    public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        //注:不可使用view=LayoutInflater.from(mContext).inflate(R.layout.item_layout,null);不然会报错
        mLayoutView= LayoutInflater.from(mContext).inflate(R.layout.item_layout,parent,false);
        ViewHolder viewHolder=new ViewHolder(mLayoutView);
        return viewHolder;
    }

    @Override
    public void onBindViewHolder(RecyclerView.ViewHolder holder, final int position) {
        final String name=mData.get(position).toString();
        ((ViewHolder)holder).mTvName.setText(name);

        mLayoutView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if(mOnRecyclerItemClickListener!=null){
                    mOnRecyclerItemClickListener.onRecyclerClick(position,name);
                }
            }
        });

        mLayoutView.setOnLongClickListener(new View.OnLongClickListener() {
            @Override
            public boolean onLongClick(View v) {
                if(mOnRecyclerItemClickListener!=null){
                    mOnRecyclerItemClickListener.onRecyclerLongClick(position,name);
                }
                return false;
            }
        });
    }

    @Override
    public int getItemCount() {
        return mData==null?0:mData.size();
    }

   class ViewHolder extends RecyclerView.ViewHolder{

        TextView mTvName;

        public ViewHolder(View view) {
            super(view);

            mTvName=(TextView)view.findViewById(R.id.tv_name);
        }
    }

    public interface OnRecyclerItemClickListener{
        public void onRecyclerClick(int position,String s);
        public void onRecyclerLongClick(int position,String s);
    }
}

然后在 Activity 中 实现监听:

public class MainActivity extends AppCompatActivity implements View.OnClickListener,LinearAdapter.OnRecyclerItemClickListener {

  private void setListener(){
        mLinearAdapter.setOnRecyclerItemClickListener(this);
    }

实现 onRecyclerClick 和 onRecyclerLongClick 方法,在次只做打印,实际在项目中再做具体逻辑

    @Override
    public void onRecyclerClick(int position, String s) {
        Log.e("","=========position=="+position);
        Log.e("","=========s=="+s);
    }

    @Override
    public void onRecyclerLongClick(int position, String s) {

    }

ok,这节的讲解就到这里,主要是讲了 RecyclerView 实现 ListView 和GridView 及点击事件的实现功能,下节研究 RecyclerView 的自定义布局



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值