Android 定制下拉刷新头部 Ultra Pull To Refresh
我们看到手机中的各种APP的花样繁多的下拉刷新是不是有点心动呢,想着自己定制自己的专门的下拉刷新,市场上比如,58同城,京东,天猫,美团等下拉刷新都是在下拉头部执行帧动画,我最近看到一个APP,就是慕课网的Android客户端,平时有时候看这个网站的学习视频,就下了一个,发现它的头部是一个圆形的水波纹效果:
看起来很Cool,正好公司有需求做官网的APP,正好可以用上公司的Logo做一个水波纹的下拉刷新,首先要实现水波纹的效果,通过解压慕课网的客户端,发现它的实现其实也是用帧动画,就是假的水波纹,但是我们不想这么早,要做一个完整的水波纹下拉刷新,那么就要实现水波纹的效果,在github上很多水波纹的实现,实现原理是用正弦与余弦曲线,这里放一个链接,有兴趣的可以看看https://github.com/john990/WaveView
然后用美工切的图往上一盖,基本雏形就出来了
ok,下面就是往下拉刷新上集成了。这里介绍一个比较牛逼的下拉刷新框架android-Ultra-Pull-to-Refresh,这个框架可以方便的定制下拉刷新的头部,接口强大,值得研究,下面我们就进行移植实现:
首先使用这个框架定制头部,需要我们把头部的View先实现出来,只要实现PtrUIHandler接口即可:
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124packagecn.zmit.ow.widget;importin.srain.cube.views.ptr.PtrFrameLayout;importin.srain.cube.views.ptr.PtrUIHandler;importandroid.annotation.SuppressLint;importandroid.content.Context;importandroid.util.AttributeSet;importandroid.view.LayoutInflater;importandroid.view.View;importandroid.widget.FrameLayout;importcn.zmit.ow.R;importcn.zmit.ow.widget.waveview.WaveView;/*** 自定义下拉刷新头部** @author Robin time 2015-02-11 14:06:33**/publicclassCustomPtrHeaderextendsFrameLayoutimplementsPtrUIHandler {WaveView wave_view;inti;publicCustomPtrHeader(Context context) {super(context);init();}publicCustomPtrHeader(Context context, AttributeSet attrs) {super(context, attrs);init();}publicCustomPtrHeader(Context context, AttributeSet attrs,intdefStyleAttr) {super(context, attrs, defStyleAttr);init();}@SuppressLint("NewApi")publicCustomPtrHeader(Context context, AttributeSet attrs,intdefStyleAttr,intdefStyleRes) {super(context, attrs, defStyleAttr, defStyleRes);init();}/*** 初始化*/privatevoidinit() {View view = LayoutInflater.from(getContext()).inflate(R.layout.custom_ptr_header,this);wave_view = (WaveView) view.findViewById(R.id.wave_view);}@OverridepublicvoidonUIReset(PtrFrameLayout frame) {}@OverridepublicvoidonUIRefreshPrepare(PtrFrameLayout frame) {}@OverridepublicvoidonUIRefreshBegin(PtrFrameLayout frame) {/* if (wave_view.getProgress()==0) {for (i = 0; i < 100; i++) {new Thread(){public void run() {UIKit.runOnMainThreadAsync(new Runnable() {@Overridepublic void run() {wave_view.setProgress(i);if (wave_view.getProgress()==100) {wave_view.setProgress(0);}}});try {Thread.sleep(200);} catch (InterruptedException e) {e.printStackTrace();}};}.start();}}*/}@OverridepublicvoidonUIRefreshComplete(PtrFrameLayout frame) {}@OverridepublicvoidonUIPositionChange(PtrFrameLayout frame,booleanisUnderTouch,bytestatus,intoldPosition,intcurrentPosition,floatoldPercent,floatcurrentPercent) {floatpercent = Math.min(1f, currentPercent);// if (status == PtrFrameLayout.PTR_STATUS_PREPARE) {wave_view.setProgress((int) (percent *100*1.0));invalidate();// }}/*** 设置波纹进度* @param progress 进度*/publicvoidsetWaveProgress(intprogress){wave_view.setProgress(progress);}}头部定义好之后,就可以调用下拉刷新的代码
123456789101112131415161718192021222324252627282930313233343536/* 创建自定义刷新头部view */header =newCustomPtrHeader(this);/* 设置刷新头部view */ptr_view.setHeaderView(header);/* 设置回调 */ptr_view.addPtrUIHandler(header);/* 设置下拉刷新监听 */ptr_view.setPtrHandler(newPtrHandler() {@OverridepublicvoidonRefreshBegin(PtrFrameLayout frame) {refresh();}@OverridepublicbooleancheckCanDoRefresh(PtrFrameLayout frame,View content, View header) {if(!StringUtils.isEmpty(mCurrentUrl)) {: mWebView.getScrollY() ==0;}else{returnmWebView.getScrollY() ==0;}}});/* 延时100秒 */ptr_view.postDelayed(newRunnable() {@Overridepublicvoidrun() {ptr_view.autoRefresh();}},100);/* 下拉时阻止事件分发 */ptr_view.setInterceptEventWhileWorking(true);这样就完成了,看下最终实现效果

本文永久地址:http://blog.it985.com/7787.html
本文出自 IT985博客 ,转载时请注明出处及相应链接。
Android 定制下拉刷新头部 Ultra Pull To Refresh的更多相关文章
- Android 实现下拉刷新和上拉加载更多的RECYCLERVIEW和SCROLLVIEW
PullRefreshRecyclerView.java /** * 类说明:下拉刷新上拉加载更多的RecyclerView * Author: gaobaiq * Date: 2016/5/9 18 ...
- Xamarin. Android实现下拉刷新功能
PS:发现文章被其他网站或者博客抓取后发表为原创了,给图片加了个水印 下拉刷新功能在安卓和iOS中非常常见,一般实现这样的功能都是直接使用第三方的库,网上能找到很多这样的开源库.然而在Xamarin. ...
- Android智能下拉刷新加载框架—看这些就够了
一些值得学习的几个下拉刷新上拉加载开源库 Android智能下拉刷新框架-SmartRefreshLayout 支持所有的 View(AbsListView.RecyclerView.WebView. ...
- android Android-PullToRefresh 下拉刷新
1.github下载地址 原作者: https://github.com/chrisbanes/Android-PullToRefresh 我自己的: https://github.com/zyj ...
- Android自定义下拉刷新
网上的下拉刷新功能很多,不过基本上都是隐藏header的,而项目里面需要只隐藏部分的header,类似QQ好友动态的效果,修改了一些现有的,最后有很多问题,所以就自己自定义了一个,逻辑也很简单,首先就 ...
- Android 自定义下拉刷新ListView
package com.dwtedx.qq.view; import android.content.Context; import android.util.AttributeSet; import ...
- 【Android】下拉刷新实现
关于这方面的文章百度下有很多,我就只写写我自己实现过程. 我觉得学习一门语言不是做了几个项目就可以认为自己会了,这只是暂时的,若没有笔记,时间长了,你是怎么解决某些问题,估计连你自己都忘了,又得费时费 ...
- Android PullToRefresh 下拉刷新,上拉很多其它,支持ScrollView,ListView,可方便拓展GridView,WebView等
在写着东西之前.从网上找到非常多这方面的源代码,可是基本没有找到惬意的.包含在GitHub上的比較有名的Android-PullToRefresh-master.思来想去还是自己写吧.当然当中借鉴了一 ...
- 032 Android智能下拉刷新框架-SmartRefreshLayout+RecyclerView的使用
1.SmartRefreshLayout介绍 SmartRefreshLayout的目标是打造一个强大,稳定,成熟的下拉刷新框架,并集成各种的炫酷.多样.实用.美观的Header和Footer. 正如 ...
随机推荐
- Cash flow
Today,we learn about the cash flow. Cash flow summary: 1.The cash flow identity:(现金恒等式) cash flow fr ...
- pcxFirefox 自定义
便携特性(ini设置) 把与firefox.exe同文件夹的tmemutil-sample.ini 改名为tmemutil.ini,设置如下: Portable=1 #便携式 Portable ...
- 【Tsinsen】【A1365】森林旅店
KD-Tree 啊哈~检验了一下自己KD-Tree的学习情况,还算可以,模板至少是记下来了. 支持插入(所以要带重建),查询最近的P个点的距离. 然而题目并没有说是按怎样的顺序输出这P个点?...(事 ...
- 【BZOJ】【3007】拯救小云公主
思路题 我的naive的做法是二分答案+判定是否有路径可走……但是没有正确理解[走的方向任意]这句话…… 其实就是说想咋走咋走= =360°无死角乱走…… 所以其实是个平面上的问题…… 我们可以换个方 ...
- 【BZOJ】【1021】【SHOI2008】Dept循环的债务
DP 去膜拜题解了>_>玛雅原来是动规…… 让我先理解一下为什么要用动规:这个题根据钱数推方案其实是无从下手的……(线性规划?……事实证明我想多了) 啦-我们先来看个超级简化版的问题:怎么 ...
- linux install
http://www.ubuntu.org.cn/index_kylin 先在官网下个Ubuntu 是个iso 然后下个UltraISO 是个软件 插好空u盘 打开软件 在菜单栏上 点击 文件-&g ...
- AutoResetEvent 运用
static AutoResetEvent are = new AutoResetEvent(true);//初始化为开 static void Main(string[] args) { //如果这 ...
- 引擎设计跟踪(九.14.2f) 最近更新: OpenGL ES & tools
之前骨骼动画的IK暂时放一放, 最近在搞GLES的实现. 之前除了GLES没有实现, Android的代码移植已经完毕: [原]跨平台编程注意事项(三): window 到 android 的 移植 ...
- SOA之(2)——SOA架构基础概念与设计框架
SOA的设计框架 设计框架与架构相关的概念紧密相连,原则.模式和架构始终是与设计共舞的. SOA服务设计的原则中记录了一个基础的设计框架: 设计特性(Design Characteristic)——由 ...
- PHP几个函数
pack: 数据装入一个二进制字符串 http_build_query: 将数组转化成URL GET参数的形式. get_class:返回对象的类名,注:即使是在父类方法中调用也是返回子类的类名. g ...