smiling1990

博客园 首页 联系 订阅 管理

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

RecyclerView与ListView原理是类似的:
都是仅仅维护少量的View并且可以展示大量的数据集。
RecyclerView:
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>

posted on 2016-06-05 20:54  smiling1990  阅读(837)  评论(0编辑  收藏  举报