灵活性比Listview更好的RecycleView

RecycleView:
是Android L版本中新添加的一个用来取代ListView的SDK,它的灵活性与可替代性比listview更好。

RecyclerView与ListView原理是类似的:
都是仅仅维护少量的View并且可以展示大量的数据集。
相同点:
1、item的排列方式:两种布局管理器:

LinearLayoutManager
GridLayoutManager

2、操作item的时候提供默认的动画效果
3、item多种布局比较方便
4、封装了item的优化
5、适配器不同
不同点:
1、分割线,RecyclerView要自定义设置
2、监听器,RecyclerView没有条目监听器,需要在适配器中自定义

RecyclerView用以下两种方式简化了数据的展示和处理:
使用LayoutManager来确定每一个item的排列方式
为增加和删除项目提供默认的动画效果
也可以定义自己的LayoutManager和添加删除动画

使用RecycleView步骤:
一、添加依赖

  //材料设计包
  compile ‘com.android.support:design:23.4.0‘

  //cardview包裹item布局,美化效果
  compile ‘com.android.support:cardview-v7:23.4.0‘

  //下拉刷新包裹RecyclerView布局
  compile ‘in.srain.cube:ultra-ptr:1.0.11‘

二、相关方法

  //如果可以确定每个item的高度是固定的,设置这个选项可以提高性能
  recyclerView.setHasFixedSize(true);

  //设置item布局之间的分割线,三个选择
  recyclerView_main.addItemDecoration(new DividerGridItemDecoration(mContext))

  //设置布局管理器
  recyclerView.setLayoutManager(LinearLayoutManager、GridLayoutManager)

  //设置动画效果
  recyclerView.setItemAnimator(new DefaultItemAnimator());

  //设置适配器
  recyclerView.setAdapter(adapter);

  //上拉加载下一页
  recyclerView_main.addOnScrollListener(//两个方法:
  线性布局管理器得到最后一条item的position;判断,然后页码++)

  //置顶功能
  recyclerView.scrollToPosition(0);

三、实现下拉刷新:

1、SwipeRefreshLayout:(系统自带的,只是下拉的时候布局并没有被下拉,需要自定义)
  //包裹RecyclerView布局
  //渐变颜色
  swipeRefreshLayout.setColorSchemeColors(...)
  //监听刷新
  swipeRefreshLayout.setOnRefreshListener(//curPage = 1;loadNetworkData();)
  //加载完成,消失图标
  swipeRefreshLayout.setRefreshing(false);

2、第三方类库:library_pullToReflect
  //布局:PullToRefreshRecyclerView

  //用法和RecycleView类似

  //如设置布局管理器、设置分割线或者分割空间、set item的高度是固定的

  //addOnScrollListener(//几乎很RecycleView一样,下拉刷新)

3、PtrFrameLayout:(需要导包,依赖项)

  //布局:PtrFrameLayout包裹RecyclerView

  //有两种:
  ①、旋转圆圈的header(类似SwipeRefreshLayout)

    Ⅰ、new一个StoreHouseHeader header,然后设置:
      header.setBackgroundColor
      header.setTextColor
      header.initWithString("LOADING...")
    Ⅱ、添加header,ptrFrameLayout.setHeaderView(header);
    Ⅲ、绑定UI与刷新状态的监听:ptrFrameLayout.addPtrUIHandler(header);
    Ⅳ、添加刷新动作监听:ptrFrameLayout.setPtrHandler(new PtrDefaultHandler)

  ②、默认的经典header(类似pullTorefresh效果)

    Ⅰ 、new一个PtrClassicDefaultHeader
    Ⅱ、添加header,ptrFrameLayout.setHeaderView(header);
    Ⅲ、绑定UI与刷新状态的监听:ptrFrameLayout.addPtrUIHandler(header);
    Ⅳ、添加刷新动作监听:ptrFrameLayout.setPtrHandler(new PtrDefaultHandler)

  // 刷新完成,让刷新Loading消失
  ptrFrameLayout_main.refreshComplete();

四、RecyclerView的适配器

  Ⅰ 、自定义适配器继承 RecyclerView.Adapter<RecyclerView.ViewHolder>
    导包正确的化可以简写成Adapter<ViewHolder>

  Ⅱ、声明属性,Context 、 数据源 、 LayoutInflater
    构造器初始化

  Ⅲ、重写方法:
    onCreateViewHolder(parent , typeView):填充View,并返回new ViewHolder(view)
    onBindViewHolder(holder , position);赋值,并加载图片
    getItemId(position)

  Ⅳ、ViewHolder内部类 继承 RecyclerView.ViewHolder
    声明UI控件,构造器初始化

  Ⅴ、重新加载数据:reloadListView(数据源 、 isClear)

  Ⅵ、额外的方法:
    notifyDataSetChanged()
    notifyItemInserted(position)
    notifyItemRangeInserted(positionStart, itemCount)
    notifyItemRemoved(position)
    notifyItemChanged(position)

  Ⅶ、如果需要设置单击监听、长按监听
    1、interface OnItemClickedListener:两个抽象方法
      void onItemClick(int position)
      boolean onItemLongClick(int position)
    2、声明接口对象:listener、声明RecyclerView对象,并在构造器中传入RecyclerView对象
    3、setOnItemClickedListener(接口对象){this.listener = listener}
    4、ViewHolder要实现View的单击、长按监听器
    5、重写单击监听器
      if (listener != null) {
        int position = recyclerView.getChildPosition(v)
        listener.onItemClick(position)
      }
        长按监听器:
      if (listener != null) {
        int position = recyclerView.getChildPosition(v)
        return listener.onItemLongClick(position)
      }
      return false
  6、主页就可以调用setOnItemClickedListener(new ...)

附CardView:
  <android.support.v7.widget.CardView
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_margin="5dp"
    android:elevation="5dp"
    app:cardCornerRadius="10dp">

</android.support.v7.widget.CardView>

时间: 2024-08-25 21:26:13

灵活性比Listview更好的RecycleView的相关文章

为了灵活使用listView,封装了BaseAdapter

为了灵活使用listView,封装了BaseAdapter. 实现了类似iOS的tableView功能.不用事先创建好所有可能需要的控件,再在运行时动态判断显示或隐藏.极大的提高了效率和减少了代码量. 主要功能: 1.可对listView进行分组管理2.每组都可以设置头与尾3.每组的多行可以定义多种布局文件4.可加载多个布局文件,从而可定制头与尾的布局文件 源码请点击github地址下载. 效果图如下: 0C5CADD9B0F72C4A98C73866C4EABA34.png API使用非常简单

女玩家的国度:调查显示美国女性比男性更倾向购买游戏机(转)

一项在美国进行的数据调查展示出了一些有趣的数据.根据这项调查,女性比男性更倾向于购买游戏主机. 美 国研究机构Pew Research Center近期发表了一篇调查结果,他们调查了美国人对于各种电子设备的拥有情况.其结论包括美国人智能手机持有量持续增加.部分人群手机持有率接近饱 和.近半美国人拥有平板电脑.电子书读者减少.台式机与笔记本状况保持不变.MP3播放器仍然没有被淘汰等. 游戏主机玩家会比较关注的调查结果自然是游戏主机在美国的拥有状况.这项抽取了948个样本进行调查了的结果展示出了有趣

RecyclerView使用介绍

RecyclerView 是Android L版本中新添加的一个用来取代ListView的SDK,它的灵活性与可替代性比listview更好.接下来通过一系列的文章讲解如何使用RecyclerView,彻底抛弃ListView. 介绍 RecyclerView与ListView原理是类似的:都是仅仅维护少量的View并且可以展示大量的数据集.RecyclerView用以下两种方式简化了数据的展示和处理: 使用LayoutManager来确定每一个item的排列方式. 为增加和删除项目提供默认的动

Introducing RecyclerView(一)

RecyclerView 是Android L版本中新添加的一个用来取代ListView的SDK,它的灵活性与可替代性比listview更好.接下来通过一系列的文章讲解如何使用RecyclerView,彻底抛弃ListView. 介绍 RecyclerView与ListView原理是类似的:都是仅仅维护少量的View并且可以展示大量的数据集.RecyclerView用以下两种方式简化了数据的展示和处理: 使用LayoutManager来确定每一个item的排列方式. 为增加和删除项目提供默认的动

RecyclerView使用 及 滑动时加载图片优化方案

RecyclerView使用 及 滑动时加载图片优化方案 简述 本篇博文主要给大家分享关于RecyclerView控件的使用及通过继承RecyclerView来实现滑动时加载图片的优化方案,也同样能解决防止图片乱序的问题,之前有在网上有看到大神对Android中ListView异步加载图片乱序问题进行过分析,并深入剖析原理后分别给出了3种对应的解决方案:一 .使用findViewWithTag.二.使用弱引用关联.三.使用Volley框架提供的NetworkImageView. 看了之后思索了很

flutter、rn、uni-app比较

前言 每当我们评估新技术时要问的第一个问题就是“它会给我们的业务和客户带来哪些价值?”,工程师们很容易对闪闪发光的新事物着迷,却经常会忽略这些新事物其实可能对我们的客户没有任何好处,反而只会让现有的工作流程更加复杂. flutter最近比较热闹,毕竟是Google出品. 但我们不是炒作热点的媒体,也不是忽悠你交学费的培训机构,我们作为实际的跨平台开发者,冷静的分析下这个东东. flutter是Google为Fuchsia操作系统设计的应用开发方式. Fuchsia OS要兼容廉价物联网设备,要求

[Android]使用RecyclerView替代ListView(一)

以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/4232560.html RecyclerView是一个比ListView更灵活的一个控件,以后可以直接抛弃ListView了.具体好在哪些地方,往下看就知道了. 首先我们来使用RecyclerView来实现ListView的效果,一个滚动列表,先看下效果图(除了有动画之外,没什么特别--): 每个item的布局如下: <?xml version="1.0&

Android 复杂布局的ListView优化思路

项目中用到一个内部复杂布局的listview,每个item中都有动态的子item,相当于listview的item中还有listview的样式.刚开始做的思路是,用一个listview,然后item中加个LinearLayout,然后代码动态的生成子item view 添加在其中,希望这样的表述大家能明白,按照这样的思路做好之后发现快速滑动的时候,一卡一顿,实在不能直视,在配置低点的机器上更是不能看. 但是因为赶进度一直没有优化,现在回头看下,虽然已经用了viewHolder但是listview

使用RecyclerView替代ListView(一)

RecyclerView是一个比ListView更灵活的一个控件,以后可以直接抛弃ListView了.具体好在哪些地方,往下看就知道了. 首先我们来使用RecyclerView来实现ListView的效果,一个滚动列表,先看下效果图(除了有动画之外,没什么特别--): 每个item的布局如下: <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http:/