Android RecyclerView添加FootView和HeadView

前提概要:

上一篇文章已经介绍过了RecyclerView的基本使用方法,原文如下:android RecyclerView布局真的只是那么简单!此篇文章算是对RecyclerView更深使用的介绍。

FootView和HeadView在ListView中的本身就有相对应的函数,但是在新潮的RecyclerView中却没有了,FootView在分页加载(上拉加载更多)中起着很重要的作用,因此也必须要学习一下了。(HeadView的添加与FootView的添加相比大致一样,在此就只讲FootView的添加了)

效果: (源码在文章结尾)

实现关键

int getItemViewType(int position):此函数是RecyclerView中自带的函数,参数为每个item的position,返回一个int类型表示类型。

此函数的作用是区分普通的item与FootView的Item,让FootView这个Item能一直处在adapter中的最下端。

在例子中定义了两种类型如下:

 //两个final int类型表示ViewType的两种类型
 private final int NORMAL_TYPE = 0;
 private final int FOOT_TYPE = 1111;

该函数如下:

 @Override
 public int getItemViewType(int position) {
 if (position == max_count - 1) {
 return FOOT_TYPE;
 }
 return NORMAL_TYPE;
 }

实现步骤

1、定义getItemViewType(int position)并且定义自己所需要的ViewType的类型。
2、在定义ViewHolder(),onCreateViewHolder()和onBindViewHolder()中都考虑两种情况,一种是普通的item,另一种是FootView。
另外默认的ViewHolder()函数中只会有View itemView一个参数,此处因为需要,所以要添加int viewType的参数,代码中如下:

//初始化viewHolder,此处绑定后在onBindViewHolder中可以直接使用
 public ViewHolder(View itemView, int viewType) {
 super(itemView);
 if (viewType == NORMAL_TYPE) {
 tvViewHolder = (TextView) itemView.findViewById(R.id.tv_view_holder);
 llViewHolder = (LinearLayout) itemView;
 } else if (viewType == FOOT_TYPE) {
 tvFootView = (TextView) itemView;
 }
 }

此处再说一下三个函数的大致作用:

ViewHolder(View itemView, int viewType):

将item布局中的控件与ViewHolder中所定义的属性绑定,更便于在onBindViewHolder()中使用。

onCreateViewHolder(ViewGroup parent, int viewType):

此函数用来创建每一个item,最后返回的不是view,而是返回的一个ViewHolder。

onBindViewHolder(ViewHolder holder, int position):

此函数中一般用来将数据绑定到item中的控件中。

代码:

结合以上分析看代码,读者应该比较容易理解了,下面附上关键adapter代码和源码地址:

public class RecyclerAdapter extends RecyclerView.Adapter<RecyclerAdapter.ViewHolder> {
 private List<String> mData;//数据
 private int max_count = 10;//最大显示数
 private Boolean isFootView = false;//是否添加了FootView
 private String footViewText = "";//FootView的内容

 //两个final int类型表示ViewType的两种类型
 private final int NORMAL_TYPE = 0;
 private final int FOOT_TYPE = 1111;

 public RecyclerAdapter(List<String> data) {
 mData = data;
 }

 public class ViewHolder extends RecyclerView.ViewHolder {
 public TextView tvViewHolder;
 public LinearLayout llViewHolder;

 public TextView tvFootView;//footView的TextView属于独自的一个layout

 //初始化viewHolder,此处绑定后在onBindViewHolder中可以直接使用
 public ViewHolder(View itemView, int viewType) {
 super(itemView);
 if (viewType == NORMAL_TYPE) {
 tvViewHolder = (TextView) itemView.findViewById(R.id.tv_view_holder);
 llViewHolder = (LinearLayout) itemView;
 } else if (viewType == FOOT_TYPE) {
 tvFootView = (TextView) itemView;
 }
 }
 }

 @Override
 public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
 View normal_views = LayoutInflater.from(parent.getContext()).inflate(
 R.layout.rc_item, parent, false);
 View foot_view = LayoutInflater.from(parent.getContext()).inflate(
 R.layout.foot_view, parent, false);

 if (viewType == FOOT_TYPE)
 return new ViewHolder(foot_view, FOOT_TYPE);
 return new ViewHolder(normal_views, NORMAL_TYPE);
 }

 @Override
 public int getItemViewType(int position) {
 if (position == max_count - 1) {
 return FOOT_TYPE;
 }
 return NORMAL_TYPE;
 }

 @Override
 public void onBindViewHolder(ViewHolder holder, int position) {
 //建立起ViewHolder中试图与数据的关联
 Log.d("xjj", getItemViewType(position) + "");
 //如果footview存在,并且当前位置ViewType是FOOT_TYPE
 if (isFootView && (getItemViewType(position) == FOOT_TYPE)) {
 holder.tvFootView.setText(footViewText);
 } else {
 holder.tvViewHolder.setText(mData.get(position) + position);
 }
 }

 @Override
 public int getItemCount() {
 if (mData.size() < max_count) {
 return mData.size();
 }
 return max_count;
 }

 //创建一个方法来设置footView中的文字
 public void setFootViewText(String footViewText) {
 isFootView = true;
 this.footViewText = footViewText;
 }
}

拓展延伸

下一篇文章中,笔者在此基础上做了一下一点改动,很容易就实现了分页加载的功能,文章地址如下:
http://blog.csdn.net/double2hao/article/details/52788708

源码地址:http://xiazai.jb51.net/201610/yuanma/AndroidPullRecyclerView(jb51.net).rar

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

(0)

相关推荐

  • Android更新UI的四种方法详解

    前言 相信每位Android开发者们都知道更新UI只能在主线程中进行,若是在子线程执行任务后需要更新UI,则需要借助handler跳转到主线程中.以下介绍几种操作UI的方法. 一.使用Handler的handleMessage() Handler的构造 public Handler() { this(null, false); } public Handler(Callback callback, boolean async) { if (FIND_POTENTIAL_LEAKS) { fina

  • Android获取手机通话记录的方法

    Android如何获取手机通话记录,本文为大家揭晓. 获取手机通话记录流程: 1. 获取ContentResolver; ContentResolver resolver = getContentResolver(); 2.resolver.query(*); 需要传入通话记录的URI:CallLog.Calls.CONTENT_URI 3.对查询得到的Cursor进行数据获取. 主要代码如下: MainActivity.java package com.noonecode.contentres

  • Android自定义View实现字母导航栏的代码

    思路分析: 1.自定义View实现字母导航栏 2.ListView实现联系人列表 3.字母导航栏滑动事件处理 4.字母导航栏与中间字母的联动 5.字母导航栏与ListView的联动 效果图: 首先,我们先甩出主布局文件,方便后面代码的说明 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/re

  • Android React-Native通信数据模型分析

    无论是计算机领域还是日常生活中,我们所言的通信,其核心都是数据信息的交换,而数据模型的优劣对通信效率有着决定性的作用. 在React-Native项目中,Javascript语言与Native两种语言(Java或OC等)间存在着大量的数据交换,也就是所谓的通信.众所周知,移动APP对性能的要求无比苛刻,如果通信数据模型设计地不合理,很可能引起多线程下的数据安全问题,以及应用性能问题,比如内存泄漏,UI绘制缓慢等. 前面几篇博客我们详细分析过React-Native的通信机制,主要有两个方向: J

  • Android实现炫酷的CheckBox效果

    首先贴出实现的效果图: gif的效果可能有点过快,在真机上运行的效果会更好一些.我们主要的思路就是利用属性动画来动态地画出选中状态以及对勾的绘制过程.看到上面的效果图,相信大家都迫不及待地要跃跃欲试了,那就让我们开始吧. 自定义View的第一步:自定义属性. <?xml version="1.0" encoding="utf-8"?> <resources> <declare-styleable name="SmoothChe

  • Android实现App中导航Tab栏悬浮的功能

    首先是"饿了么"导航Tab栏悬浮的效果图. 大家可以看到上图中的"分类"."排序"."筛选"会悬浮在app的顶部,状态随着ScrollView(也可能不是ScrollView,在这里姑且把这滑动的UI控件当作ScrollView吧)的滚动而变化.像这种导航Tab栏悬浮的作用相信大家都能体会到,Tab栏不会随着ScrollView等的滚动而被滑出屏幕外,增加了与用户之间的交互性和方便性. 看到上面的效果,相信大家都跃跃欲试了,那

  • Android RecyclerView添加上拉加载更多功能

    上一篇文章已经介绍了如何为RecyclerView添加FootView,在此基础上,要添加分页加载的功能其实已经很简单了. 上一篇文章地址:为RecyclerView添加FootView和HeadView 效果:(源码在文章结尾) 实现关键 在上一篇代码的基础上,只需要在onBindViewHolder(ViewHolder holder, int position)函数中添加一定修改就可以了,如下: @Override public void onBindViewHolder(ViewHold

  • PHP简单判断iPhone、iPad、Android及PC设备的方法

    本文实例讲述了PHP简单判断iPhone.iPad.Android及PC设备的方法.分享给大家供大家参考,具体如下: 因为工作需要我们需要知道是什么样了用户访问了我网站了,现在的移动设备种类多了,下面我们一起来看小编整理的一段PHP判断iPhone.iPad.Android.PC设备的例子. 我将使用Windows系统的设备定为PC,毕竟博客面向中国用户,大部分家用设备还是用的Windows系统. 原理是判断浏览器提交的USER AGENT,代码如下: <?php //获取USER AGENT

  • Android Gradle Build Error:Some file crunching failed, see logs for details的快速解决方法

    错误日志:Error:java.lang.RuntimeException: Some file crunching failed, see logs for details Log: FAILURE: Build failed with an exception. * What went wrong: Execution failed for task ':app:mergeDebugResources'. > Error: java.lang.RuntimeException: Crunch

  • Android 系统net和wap接入点的区别

    我们使用Android设备连接网络时,如果是wap接入点就需要设置代理,而电信和移动联通的代理并不相同,移动和联通的wap代理都是10.0.0.172:80,电信的wap代理是10.0.0.200:80,所以进行Android开发时很有必要判断接入点. 接入点的类型 Net网络:运营商(移动联通电信)net网络,wifi,usb网络共享 Wap网络:移动联通wap(代理相同:10.0.0.172:80),电信wap(代理:10.0.0.200:80) 这样看来就可以抽象出三种网络类型:联通移动w

随机推荐