android ListView下拉刷新 上拉加载更多
背景
最近在公司的项目中要使用到ListView的下拉刷新和上拉加载更多(貌似现在是个项目就有这个功能!哈哈),其实这个东西GitHub上很多,但是我感觉那些框架太大,而且我这个项目只用到了ListView没有用到其他的,所以我就想自己写一个吧!
(注:本篇文章高手就自动略过吧!!!!)
一.实现步骤
- 自定义View继承ListView
- 向ListView添加头部View和尾部View(还有人不知道吗?哈哈)
- 隐藏头部View和尾部View (这个地方有个坑,我在代码介绍的时候会注明)
- 重写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)
至此我们知道了总共用四中状态!我们可以用四个静态常亮来表示。当然,我们也因该定义个变量表示当前的状态 默认当然是无状态啦!!!看代码:

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

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

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


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

至此 本篇博客就要结束啦!可以有人要说了你骗人 !还有上拉加载更多呢?其实这个比下拉刷新简单的太多了!我就不贴代码了!!!大家自己去摸索吧!!
附上代码下载链接
android ListView下拉刷新 上拉加载更多的更多相关文章
- Android 自定义 ListView 上下拉动“刷新最新”和“加载更多”歌曲列表
本文内容 环境 测试数据 项目结构 演示 参考资料 本文演示,上拉刷新最新的歌曲列表,和下拉加载更多的歌曲列表.所谓"刷新最新"和"加载更多"是指日期.演示代码 ...
- SwipeRefreshLayout实现下拉刷新上滑加载
1. 效果图 2.RefreshLayout.java package myapplication.com.myapplication; import android.content.Context; ...
- Android 下拉刷新上啦加载SmartRefreshLayout + RecyclerView
在弄android刷新的时候,可算是耗费了一番功夫,最后发觉有现成的控件,并且非常好用,这里记录一下. 原文是 https://blog.csdn.net/huangxin112/article/de ...
- juery下拉刷新,div加载更多元素并添加点击事件(二)
buffer.append("<div class='col-xs-3 "+companyId+"' style='padding-left: 10px; padd ...
- Android如何定制一个下拉刷新,上滑加载更多的容器
前言 下拉刷新和上滑加载更多,是一种比较常用的列表数据交互方式. android提供了原生的下拉刷新容器 SwipeRefreshLayout,可惜样式不能定制. 于是打算自己实现一个专用的.但是下拉 ...
- 移动端下拉刷新上拉加载-mescroll.js插件
最近无意间看到有这么一个上拉刷新下拉加载的插件 -- mescroll.js,个人感觉挺好用的,官网地址是:http://www.mescroll.com 然后我就看了一下文档,简单的写了一个小dem ...
- ListView实现Item上下拖动交换位置 并且实现下拉刷新 上拉加载更多
ListView实现Item上下拖动交换位置 并且实现下拉刷新 上拉加载更多 package com.example.ListViewDragItem; import android.app.Ac ...
- ListView下拉刷新上拉加载更多实现
这篇文章将带大家了解listview下拉刷新和上拉加载更多的实现过程,先看效果(注:图片中listview中的阴影可以加上属性android:fadingEdge="none"去掉 ...
- listview下拉刷新上拉加载扩展(二)-仿美团外卖
经过前几篇的listview下拉刷新上拉加载讲解,相信你对其实现机制有了一个深刻的认识了吧,那么这篇文章我们来实现一个高级的listview下拉刷新上拉加载-仿新版美团外卖的袋鼠动画: 项目结构: 是 ...
- MaterialRefreshLayout+ListView 下拉刷新 上拉加载
效果图是这样的,有入侵式的,非入侵式的,带波浪效果的......就那几个属性,都给出来了,自己去试就行. 下拉刷新 上拉加载 关于下拉刷新-上拉加载的效果,有许许多多的实现方式,百度了一下竟然有几十种 ...
随机推荐
- oracle存储过程实例
oracle存储过程实例 分类: 数据(仓)库及处理 2010-05-03 17:15 1055人阅读 评论(2)收藏 举报 认识存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的P ...
- Codeforces Beta Round #13 E. Holes 分块暴力
E. Holes Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/13/problem/E Des ...
- NGINX源代码剖析 之 CPU绑定(CPU亲和性)
作者:邹祁峰 邮箱:Qifeng.zou.job@gmail.com 博客:http://blog.csdn.net/qifengzou 日期:2014.06.12 18:44 转载请注明来自&quo ...
- 【原创】AltiumDesigner 6 的自定义菜单
AltiumDesigner 6 的自定义菜单,数据保存在DXP.RCS文件中通过测试,添加一个自定义菜单名为HHH,然后用Editplus在C:\Users\pcittsy\AppData\Roam ...
- Java和C++中多态的实现方式
多态是面向对象的最主要的特性之一,是一种方法的动态绑定,实现运行时的类型决定对象的行为.多态的表现形式是父类指针或引用指向子类对象,在这个指针上调用的方法使用子类的实现版本.多态是IOC.模板模式实现 ...
- POJ 3624 Charm Bracelet
DP 一直是心中痛,不多说了,这个暑假就坑在这上了. 这暑假第一道DP题,01背包问题. 题意是说物品有 重量和价值 ,但你能承受的重量有限,问你能带的最大价值. 这题数组开大点,尽管不知道有啥坑点, ...
- sql查询行转列
昨天下午碰到一个需求,一个大约30万行的表,其中有很多重复行,在这些行中某些字段值是不重复的. 比如有ID,NAME,CONTRACT_id,SALES,PRODUCT等,除了PRODUCT字段,其余 ...
- what is docker
尽管之前久闻Docker的大名了,但是天资愚钝,对其到底是个啥东西一直摸不清,最近花了一段时间整理了一下,算是整理出一点头绪来. 官网的介绍是这样的: Docker is an open platfo ...
- Jquery 扩展方法
$.fn是指jquery的命名空间,加上fn上的方法及属性,会对jquery实例每一个有效. 如扩展$.fn.abc() 那么你可以这样子:$("#div").abc(); 通常使 ...
- Border绘制虚线框(转)
<Grid> <Border HorizontalAlignment="Center" VerticalAlignment="Center" ...