Android RecyclerView使用方法详解

本文为大家分享了Android RecyclerView使用方法,供大家参考,具体内容如下

1、RecyclerView 是在Android support - v7 里面提供的 新的列表组件,用来替代传统的ListView。

. 要使用RecyclerView 需要给我工程添加 support:recycle-v7 的支持: app 右键 - Open Module Settings - Dependencies(依赖项) - 点 + 号 - 添加一个库 upport:recycle-v7  - 代码实现

. 给TextView 呈现数据

public class MainActivity extends AppCompatActivity {
  //创建RecyclerView
  private RecyclerView recyclerView;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    recyclerView = new RecyclerView(this);
    //把它当做Activity的内容布局
    setContentView(recyclerView);

    //设置RecyclerView的布局
    recyclerView.setLayoutManager(newLinearLayoutManager(this));

    //为 RecyclerView填充内容 - 创建一个 Adapter - 需要重写三个函数
    recyclerView.setAdapter(newRecyclerView.Adapter() {

      //首先自定义一个类继承RecyclerView.ViewHolder 实现构造函数
      class ViewHolerextends RecyclerView.ViewHolder{

        // 在ViewHolder 里面绑定子对象的视图
        private TextViewtv;

        public ViewHoler(TextView itemView) {
          super(itemView);
          tv = itemView;//通过这种方式 TextView就可以跟ViewHolder进行关联
        }

        //在外界公开一个函数 getTV() ,用它来返回这个TextView
        public TextView getTV(){
          return tv;
        }
      }
      //创建 ViewHolder的方法
      @Override
      public RecyclerView.ViewHolderonCreateViewHolder(ViewGroup parent, intviewType) {

        return new ViewHoler(newTextView(parent.getContext()));
      }
      //onBindViewHolder 可以对TextView进行赋值, - 在外界进行配置
      @Override
      public void onBindViewHolder(RecyclerView.ViewHolder holder, intposition) {
        ViewHoler vh = (ViewHoler) holder;
        vh.getTV().setText("Item " + position);
      }
      //获取RecyclerView子对象的数量
      @Override
      public int getItemCount() {
        return 1000;
      }
    });
  }
}

. 用数组 承载 展示数据

@Override
public void onBindViewHolder(RecyclerView.ViewHolder holder, intposition) {
ViewHoler vh = (ViewHoler) holder;
vh.getTV().setText(data[position]);
}

    @Override
    public int getItemCount() {
      return data.length;
    }

    /*写一个数组呈现出来 从网络一系列的途径获取的数据都是数组呈现出来*/
    private String[] data = new String[]{"hello","wang","xiaobao"};
  });
}

2、使用资源文件自定义列表项

. 因为我们在之前使用自定义列表项的方式直接写程序,在很多时候你会发现如果直接在程序里面写界面,最终修改是非常麻烦的,所以我们要学会使用资源文件来配置。

. 新建一个资源文件   layout - New - Layout resource file - list_cell - 添加两个TextView

然后

class MyAdapter extends RecyclerView.Adapter {

  /* new RecyclerView.Adapter() 可以转移到单独的文件里去
   * 在Adapter()内部: 点击右键 - Refactor(重构) - Move -移到一个类里面去.
   * 它会全自动的把匿名类 提取成一个内部类。
   *
   * 之后再继续移动到一个单独的文件里面。
   */
  class ViewHolerextends RecyclerView.ViewHolder {
    private Viewroot; //暂无意义,参考上面案例,可以实现与外界连接
    private TextView tvTitle,tvContent;

    public ViewHoler(View root) {
      super(root);
      //我们知道传进来的布局就是list_cell;创建之后就可以获取到这两个控件。
      tvTitle = root.findViewById(R.id.tv_title);
      tvContent = root.findViewById(R.id.tv_content);
    }
    //需要添加两个get方法被外界访问到的
    public TextViewgetTvTitle() {
      return tvTitle;
    }

    public TextViewgetTvContent() {
      return tvContent;
    }
  }

  @Override
  public RecyclerView.ViewHolderonCreateViewHolder(ViewGroup parent, intviewType) {
    /*
    *之后要创建View,不是new TextView()我们要换种方式,根据一个资源进行创建,使用LayoutInflater.from
    * LayoutInflater : 布局解释器,用布局解释器解析一个布局,布局首先传进来的是一个资源,资源就是建立的cell
    * 第二项:是我们创建的布局的根对象,这里传 null ,通过这种方式我们就创建了这种布局。然后获取控件
    */
    return new ViewHoler(LayoutInflater.from(parent.getContext()).inflate(R.layout.list_cell,null));
  }

  @Override//分别来进行配置 //我们来创建一个数据对象。创建构造函数
  public void onBindViewHolder(RecyclerView.ViewHolder holder, intposition) {
    ViewHoler vh = (ViewHoler) holder;
    //首先获取到这些数据
    Cell_Data cd = data[position];
    vh.getTvTitle().setText(cd.title);
    vh.getTvContent().setText(cd.title);
  }

  //创建完对象之后,它是一个CellData[]
  private Cell_Data[]data = new Cell_Data[]{newCell_Data("王小宝","hhh"),newCell_Data("新闻","这个新闻不错")};

  @Override
  public int getItemCount() {
    return data.length;
  }
}

//创建一个数据对象的
//列表项数据
public class Cell_Data {

  public Cell_Data(String title,String content) {
    this.title= title;
    this.content = content;
  }

  public String title = "title";
  public String content = "content";
}

3、RecyclerView 的布局样式

protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  recyclerView = new RecyclerView(this);
  setContentView(recyclerView);
  //true ;是否翻转 可以左右拖动 - 线性布局
  recyclerView.setLayoutManager(newLinearLayoutManager(MainActivity.this,LinearLayoutManager.HORIZONTAL,true));
  //创建一个表格布局默认是垂直方向的可以上下
  recyclerView.setLayoutManager(newGridLayoutManager(this,3));

  recyclerView.setAdapter(newMyAdapter());

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android ExpandableRecyclerView使用方法详解

    本文为大家分享了Android ExpandableRecyclerView的使用,供大家参考,具体内容如下 1.目前只支持两级结构. 2.支持所有组同时全部展开,支持同一时间只能展开一组. 3.GroupView,ChildView高度自定义. 4.支持初始化数据时,指定展开某组数据. 5.支持GroupItem,ChildItem的Onlick,OnLongClick事件. 6.展开收起带动画. 效果图: 使用步骤:加入依赖 compile 'com.drawthink:expandable

  • Android RecyclerView的简单使用

    本文实例为大家分享了Android RecyclerView使用的具体代码,供大家参考,具体内容如下 package com.itheima74.recyclerview; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.support.v7.widget.GridLayoutManager; import android.support.v7.widget.Rec

  • Android如何使用RecyclerView打造首页轮播图

    先看看效果图: 停在中间自动翻页 序言:最近接到一个任务,做一个类似上面自动翻页的功能.可以看到,这一屏中有三张图片显示出来了,有两张没有显示完全,看到设计图的时候第一反应是可以用viewpager来实现,但是任务却跟你开了一个天大的玩笑,要求是以最左边的图片为基准,也就是说,左边的图片也得显示完全,就像下图所示,后来仔细想想viewpager好像没有这样的功能,也有可能是我不知道,我也没有找到这样的文章或者信息,希望知道的简友私戳交流一下,感激不尽,好了,言归正传 停在左边 在开始之前呢,首先

  • Android使用分类型RecyclerView仿各大商城首页

    **正所谓,一入商城深似海~ 商城类的App,确实是有许多东西值得学习,但是只要略微斟酌一下,你又会发现,它们之间存在着许多不谋而合的相似,也就是所谓的雷同~既然如此,让我们也来接下地气,先从一个简单的首页做起吧~** 实现的效果如下图: 1.大布局就是一个简单的RecyclerView: 也可以通过添加多个header实现 4.这里我仅以四种类型为例 /** * 4种类型 */ /** * 类型1:黑色星期五--使用banner实现 */ public static final int BLA

  • Android使用RecyclerView实现今日头条频道管理功能

    使用过今日头条的伙计们对这个效果肯定很熟悉.拖拽可排序,点击标签后可以删除.今天我们采用RecyclerView来实现. 实现思路: 通过ItemTouchHelper来绑定RecyclerView的子控件触摸事件. 当滑动拖拽的时候,通知适配器来交换两个子控件的显示位置. 更改数据源,使数据源与子空间显示内容一致. 这就是实现的基本思路,是不是很简单?当然,首先要了解一下ItemTouchHelper这哥们儿是干啥的,有什么作用. This is a utility class to add

  • Android使用RecyclerView实现列表数据选择操作

    这些时间做安卓盒子项目,因为安卓电视的显示器比较大,所以一个界面显示 很多数据 ,最多的时候,一个Actvity中用到了好几个RecyclerView. 在RecyclerView中实现Item选中处理时,发现用CheckBox的OnCheckedChangeListener监听事件时,会达不到预期,所以用了OnClickListener来实现. 主界面代码: public class CheckRecyclerViewActivity extends AppCompatActivity imp

  • Android RecyclerView基本使用详解

    什么是RecyclerView 关于RecyclerView,是一个主要用于展示和回收View的有一个控件,在官用了一句话来概括 RecyclerView 是一种通过提供有限的数据项窗口有效显示大数据集的视图. 基提供几个基本的功能, 控制其显示的方式 --->LayoutManager-(必需) 控制Item间的间隔 --->ItemDecoration--(非必需) 控制Item增删的动画--->ItemAnimator--(非必需) 以上就可以完成ListView大部的功能了,但是

  • Android使用Recyclerview实现图片水平自动循环滚动效果

    简介: 本篇博客主要介绍的是如何使用RecyclerView实现图片水平方向自动循环(跑马灯效果) 效果图:  思路: 1.准备m张图片 1.使用Recyclerview实现,返回无数个(实际Interge.MAXVALUE)item,第n个item显示第n%m张图片 3.使用recyclerview.scrollBy  每个一段时间水平滚动一段距离 4.通过layoutManager.findFirstVisibleItemPosition()获取当前显示的第一个View是第几个item,上面

  • android使用ItemDecoration给RecyclerView 添加水印

    前言 项目中有使用到水印效果,如下图所示.在实现过程中,最终选用ItemDecoration来实现,其中有两大步骤:自定义Drawable来完成水印图片.使用ItemDecoration来布局水印. Demo在 WatermarkFragment 中,效果图如下: 1. 自定义Drawable完成水印图片 public class MyDrawable extends Drawable { Paint mPaint; public MyDrawable() { mPaint = new Pain

  • RecyclerView的简单使用

    RecyclerView的功能很强大,本文为大家分享RecyclerView的简单使用方法. 效果图: activity_main.xml: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertica

随机推荐