背景

最近在公司的项目中要使用到ListView的下拉刷新和上拉加载更多(貌似现在是个项目就有这个功能!哈哈),其实这个东西GitHub上很多,但是我感觉那些框架太大,而且我这个项目只用到了ListView没有用到其他的,所以我就想自己写一个吧!
(注:本篇文章高手就自动略过吧!!!!)

一.实现步骤

  1. 自定义View继承ListView
  2. 向ListView添加头部View和尾部View(还有人不知道吗?哈哈)
  3. 隐藏头部View和尾部View (这个地方有个坑,我在代码介绍的时候会注明)
  4. 重写onTouchEvent()方法 (这个地方注意点很多 要不然运行的时候 会出现很多细节上的问题)

二.代码实现

终于到了写代码的时候啦!!我们按照上面的步骤一步一步的来

1.自定义View继承ListView 同时也要继承 AbsListView.OnScrollListener 因为要我们要记录ListView的状态.上代码:

2.向ListView添加头部View和尾部View 这里如果直接调用view的getMeasuredHeight()方法来获取view的高度的话,你就会发这个这个高度值为0,所以我们在调用之前应该先执行下面段代码:

得到view高度之后 就可以获取到头部View和尾部view的高度啦!在看代码:

3.隐藏头部View和尾部View 这一步在第二部的代码片段中已经实现啦!就是设置两个View的paddingTop值 注意是负的啊 要不然不能隐藏哦!

4.重写onTouchEvent()方法 重头戏来啦!

1.首先我们再来分析一下 下拉刷新的过程:

(1).用户没有任何操作

(2).用户在在下拉

(3).下拉一定距离 提示用户松开刷新

(4).正在刷新

(5).刷新完成-->(1)

至此我们知道了总共用四中状态!我们可以用四个静态常亮来表示。当然,我们也因该定义个变量表示当前的状态 默认当然是无状态啦!!!看代码:

  1. 分析完状态之后,我们还需注意几点小问题:就是我们在什么时候才能下拉刷新呢?(大家好好想想!!) 就是当前页面中出现我们ites中的第一个(就是ListView显示列表中的第一个),此时下来才是有效的!!那怎么才知道当前页面中的第一个是ListView列表中的第一个呢?其实很简单 在继承ListView的时候我们继承了AbsListView.OnScrollListener这个回调接口!该接口有两个!我们先看其中一个回调方法

代码中注释很清楚 我就不说明了!!

3.至此,我们就要开始写最核心的部分了(请大家睁大双眼)
(1).首先我们的第一步操作就是按下屏幕 此时当然触发Acion_Down啦。此时就是我们判断当前页面的第一个是否是ListView列表中的第一个啦 如果是的 我们设置个标志位记录下。同时呢 我们也得记录下按下去的X Y值。看代码


(2).下面就是开始向下滑动了 这里我直接上代码(有注释 不要担心看不懂。如果看不懂就多看几遍!!哈哈)
代码略长分了两段上传:


仔细的看的人可以能要问了。这两个函数setHeaderViewTopPadding()和updateHeadView()是什么鬼!其实看名字就知道啦!第一个是用来更新view的paddingtop值的!第二个是用来更新View的内容的!
4.最后一步啦 当用户松开手指的时候:其实很好判断 :无非就是判断当前状态是什么 如果是 PULLTOREALSE 松开就是刷新 不是的话就恢复出事状态。看代码:

至此 本篇博客就要结束啦!可以有人要说了你骗人 !还有上拉加载更多呢?其实这个比下拉刷新简单的太多了!我就不贴代码了!!!大家自己去摸索吧!!
附上代码下载链接

代码

android ListView下拉刷新 上拉加载更多的更多相关文章

  1. Android 自定义 ListView 上下拉动“刷新最新”和“加载更多”歌曲列表

    本文内容 环境 测试数据 项目结构 演示 参考资料 本文演示,上拉刷新最新的歌曲列表,和下拉加载更多的歌曲列表.所谓"刷新最新"和"加载更多"是指日期.演示代码 ...

  2. SwipeRefreshLayout实现下拉刷新上滑加载

    1. 效果图 2.RefreshLayout.java package myapplication.com.myapplication; import android.content.Context; ...

  3. Android 下拉刷新上啦加载SmartRefreshLayout + RecyclerView

    在弄android刷新的时候,可算是耗费了一番功夫,最后发觉有现成的控件,并且非常好用,这里记录一下. 原文是 https://blog.csdn.net/huangxin112/article/de ...

  4. juery下拉刷新,div加载更多元素并添加点击事件(二)

    buffer.append("<div class='col-xs-3 "+companyId+"' style='padding-left: 10px; padd ...

  5. Android如何定制一个下拉刷新,上滑加载更多的容器

    前言 下拉刷新和上滑加载更多,是一种比较常用的列表数据交互方式. android提供了原生的下拉刷新容器 SwipeRefreshLayout,可惜样式不能定制. 于是打算自己实现一个专用的.但是下拉 ...

  6. 移动端下拉刷新上拉加载-mescroll.js插件

    最近无意间看到有这么一个上拉刷新下拉加载的插件 -- mescroll.js,个人感觉挺好用的,官网地址是:http://www.mescroll.com 然后我就看了一下文档,简单的写了一个小dem ...

  7. ListView实现Item上下拖动交换位置 并且实现下拉刷新 上拉加载更多

    ListView实现Item上下拖动交换位置  并且实现下拉刷新  上拉加载更多 package com.example.ListViewDragItem; import android.app.Ac ...

  8. ListView下拉刷新上拉加载更多实现

    这篇文章将带大家了解listview下拉刷新和上拉加载更多的实现过程,先看效果(注:图片中listview中的阴影可以加上属性android:fadingEdge="none"去掉 ...

  9. listview下拉刷新上拉加载扩展(二)-仿美团外卖

    经过前几篇的listview下拉刷新上拉加载讲解,相信你对其实现机制有了一个深刻的认识了吧,那么这篇文章我们来实现一个高级的listview下拉刷新上拉加载-仿新版美团外卖的袋鼠动画: 项目结构: 是 ...

  10. MaterialRefreshLayout+ListView 下拉刷新 上拉加载

    效果图是这样的,有入侵式的,非入侵式的,带波浪效果的......就那几个属性,都给出来了,自己去试就行. 下拉刷新 上拉加载 关于下拉刷新-上拉加载的效果,有许许多多的实现方式,百度了一下竟然有几十种 ...

随机推荐

  1. js页面文字选中后分享到新浪微博实现

    demo您可以狠狠地点击这里:js文字选中分享到新浪微博demo 方法与代码 选中即分享的功能看上去比较高级,其实实现是相当简单的.其中的会让人头大,一般人也不感兴趣的原理这里就直接跳过.这个js文字 ...

  2. 【java开发系列】— JDOM创建、改动、删除、读取XML文件

    有非常多中操作XML文件的方法,这里介绍一下JDOM的用法和技巧. JDOM下载地址 创建XML文档 XML文件是一种典型的树形文件,每一个文档元素都是一个document元素的子节点. 而每一个子元 ...

  3. IntervalZero RTX 2014

    2692407267@qq.com,很多其它内容请关注http://user.qzone.qq.com/2692407267 IntervalZero RTX 2014   上图 watermark/ ...

  4. c# 轻量级ORM框架 之 WhereHelper (二)

    上篇文章发布了一些设计orm框架基层的和实现,有朋友提出WhereHelper是亮点,能被认可我表示高兴. 我就把WhereHelper设计思想和代码公开下. WhereHelper 的概念就是再拼接 ...

  5. Codeforces Round #308 (Div. 2) A. Vanya and Table 暴力

    A. Vanya and Table Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/552/pr ...

  6. 2013 Fench Open quart-semifnl press conference

    http://v.youku.com/v_show/id_XNTY3NTAwOTA4.html?firsttime=179 Novak, very  congradutlations,  to rea ...

  7. Javascript加载执行问题探索

    转自:http://www.cnblogs.com/huangxincheng/archive/2011/12/04/2275988.html 前言 最近研究MongoDB数据库,无意间发现的好博客, ...

  8. Creating a CSRF protection with Spring 3.x--reference

    reference from:http://info.michael-simons.eu/2012/01/11/creating-a-csrf-protection-with-spring-3-1/ ...

  9. 关于linux内核模块Makefile的解析

    转载:http://www.embeddedlinux.org.cn/html/yingjianqudong/201403/23-2820.html Linux内核是一种单体内核,但是通过动态加载模块 ...

  10. IOS 按比例裁剪图片

    拍照或者从图片库中获取图片 操作过程中容易闪退,也总会有内存压力警告,第一步,首先可以考虑裁剪图片,实际上可能不需要那么大的.其次可以考虑把耗时的比如存储过程放进线程. 这里封装裁剪图片的类方法. / ...