1.介绍:

不足就是不支持上拉加载.
2.使用
首先添加依赖到项目
compile 'in.srain.cube:ultra-ptr:1.0.11'
在Xml中使用
<in.srain.cube.views.ptr.PtrFrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" xmlns:app="http://schemas.android.com/apk/res-auto" android:id="@+id/food_refreshLayout" android:layout_width="match_parent" android:layout_height="match_parent" app:ptr_resistance="1.7" //设置下拉的阻尼系数,值越大感觉越难下拉 app:ptr_ratio_of_header_height_to_refresh="1.2" //设置超过头部的多少时,释放可以执行刷新操作 app:ptr_duration_to_close="200" //:设置下拉回弹的时间 app:ptr_duration_to_close_header="300" //设刷新完成,头部回弹时间,注意和前一个进行区别 app:ptr_keep_header_when_refresh="true" //设置刷新的时候是否保持头部 app:ptr_pull_to_fresh="false"> //设置下拉过程中执行刷新,我们一般设置为false <ScrollView android:layout_width="match_parent" android:layout_height="match_parent" > </ScrollView> </in.srain.cube.views.ptr.PtrFrameLayout>
在代码中使用
在代码中使用非常简单,简单几部搞定:
1.找到控件,添加头部刷新布局
mFoodRefreshLayout = (PtrFrameLayout) findViewById(R.id.food_refreshLayout); //这里是一个自定义的头部刷新布局,自带的也有一个布局 new PtrDefaultHandler(); PtrClassicHeader header = new PtrClassicHeader(this); //将头布局添加 mFoodRefreshLayout.addPtrUIHandler(header);
2.不仅仅是添加头布局,还需要设置到控件中 注:特别重要,不然没显示
mFoodRefreshLayout.setHeaderView(header); //设置刷新头布局
3.给刷新控件设置下拉监听
mFoodRefreshLayout.setPtrHandler(new PtrHandler() {
@Override
public void onRefreshBegin(PtrFrameLayout frame) {
//在这里写自己下拉刷新数据的请求
//需要结束刷新头
mFoodRefreshLayout.refreshComplete();
}
@Override
public boolean checkCanDoRefresh(PtrFrameLayout frame, View content, View header) {
// 默认实现,根据实际情况做改动
return PtrDefaultHandler.checkContentCanBePulledDown(frame, content, header);
}
});
3.自定义请求头
上面是对基本使用进行了介绍,相信大家在使用下拉刷新时都需要用到自定义布局,其实也很简单,在上面代码添加刷新头时就创建自定义的头部即可,下面对自定义头部的几个方法做简单介绍:
public class PtrClassicHeader extends FrameLayout implements PtrUIHandler{ //实现接口
private ImageView mPush;
//在代码创建对象
public PtrClassicHeader(Context context) {
super(context);
initView();
}
public PtrClassicHeader(Context context, AttributeSet attrs) {
super(context, attrs);
initView();
}
public PtrClassicHeader(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
initView();
}
//初始化自定义布局文件
private void initView() {
//这里加载自定义的布局文件
View header = LayoutInflater.from(getContext()).inflate(R.layout.item_push_header_layout, this);
//找到布局内部的控件
mPush = (ImageView) header.findViewById(R.id.header_iv);
}
//定义一个动画,方便下面的调用
public void initAnim(){
ObjectAnimator anim = ObjectAnimator.ofFloat(mPush, "rotation", 0f, 180f);
anim.setDuration(500);
anim.start();
}
//初始化状态
@Override
public void onUIReset(PtrFrameLayout frame) {
//这个方法可以不用管 也可以在这里关闭动画
}
//开始向下拉的时候调用
@Override
public void onUIRefreshPrepare(PtrFrameLayout frame) {
initAnim(); //这里可以执行动画效果
}
//刷新过程时调用
@Override
public void onUIRefreshBegin(PtrFrameLayout frame) {
//可以不断的改变动画效果以及切换显示的控件
//判断是否可以刷新
if (frame.isPullToRefresh()) {
mTitleTextView.setText("释放刷新");
} else {
mTitleTextView.setText("下拉加载");
}
}
//刷新完成后调用,向上移动时调用
@Override
public void onUIRefreshComplete(PtrFrameLayout frame) {
//可以不断的改变动画效果以及切换显示的控件
mTitleTextView.setText("加载中...");
animationDrawable.stop(); //模拟动画
animationDrawable.start();
}
//重复下拉
@Override
public void onUIPositionChange(PtrFrameLayout frame, boolean isUnderTouch, byte status, PtrIndicator ptrIndicator) {
//在同一次下拉中不断向上向下移动,这里可以不断改变显示效果
//示例代码: 可以当模板使用
final int mOffsetToRefresh = frame.getOffsetToRefresh();
final int currentPos = ptrIndicator.getCurrentPosY(); //获取到下拉的高度
final int lastPos = ptrIndicator.getLastPosY(); //最大下拉的高度
//根据下拉的位置进行控件的显示
if (currentPos < mOffsetToRefresh && lastPos >= mOffsetToRefresh) {
if (isUnderTouch && status == PtrFrameLayout.PTR_STATUS_PREPARE) {
crossRotateLineFromBottomUnderTouch(frame); //调用方法
}
} else if (currentPos > mOffsetToRefresh && lastPos <= mOffsetToRefresh) {
if (isUnderTouch && status == PtrFrameLayout.PTR_STATUS_PREPARE) {
crossRotateLineFromTopUnderTouch(frame); //调用方法
}
}
}
//下拉到可以刷新时显示
private void crossRotateLineFromTopUnderTouch(PtrFrameLayout frame) {
if (!frame.isPullToRefresh()) {
mTitleTextView.setText("释放刷新");
}
}
//动态改变文字
private void crossRotateLineFromBottomUnderTouch(PtrFrameLayout frame) {
if (frame.isPullToRefresh()) {
mTitleTextView.setText("释放刷新");
} else {
mTitleTextView.setText("下拉加载");
}
}
}
}
4.解决冲突
ViewPager滑动冲突: 直接调用: disableWhenHorizontalMove()
如有不懂可查看:https://github.com/liaohuqiu/android-Ultra-Pull-To-Refresh/blob/master/README-cn.md
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# Android下拉刷新PtrFrameLayout
# android
# 下拉刷新
相关文章:
c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】
制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?
建站之星如何快速解决建站难题?
相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?
html制作网站的步骤有哪些,iapp如何添加网页?
浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?
图册素材网站设计制作软件,图册的导出方式有几种?
装修招标网站设计制作流程,装修招标流程?
定制建站是什么?如何实现个性化需求?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?
如何获取免费开源的自助建站系统源码?
网站微信制作软件,如何制作微信链接?
javascript中的try catch异常捕获机制用法分析
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
企业网站制作公司网页,推荐几家专业的天津网站制作公司?
5种Android数据存储方式汇总
上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?
如何选择靠谱的建站公司加盟品牌?
洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?
如何通过西部数码建站助手快速创建专业网站?
建站主机CVM配置优化、SEO策略与性能提升指南
官网建站费用明细查询_企业建站套餐价格及收费标准指南
盘锦网站制作公司,盘锦大洼有多少5G网站?
宝塔建站教程:一键部署配置流程与SEO优化实战指南
英语简历制作免费网站推荐,如何将简历翻译成英文?
,购物网站怎么盈利呢?
微信小程序制作网站有哪些,微信小程序需要做网站吗?
如何在腾讯云免费申请建站?
台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?
如何通过VPS建站实现广告与增值服务盈利?
如何在新浪SAE免费搭建个人博客?
建站主机空间推荐 高性价比配置与快速部署方案解析
香港服务器网站推广:SEO优化与外贸独立站搭建策略
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
c# 在高并发下使用反射发射(Reflection.Emit)的性能
焦点电影公司作品,电影焦点结局是什么?
整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?
建站主机类型有哪些?如何正确选型
制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?
广州营销型建站服务商推荐:技术优势与SEO优化解析
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
专业公司网站制作公司,用什么语言做企业网站比较好?
头像制作网站在线制作软件,dw网页背景图像怎么设置?
微课制作网站有哪些,微课网怎么进?
定制建站模板如何实现SEO优化与智能系统配置?18字教程
免费网站制作appp,免费制作app哪个平台好?
北京网站制作公司哪家好一点,北京租房网站有哪些?
如何快速生成凡客建站的专业级图册?
如何通过虚拟机搭建网站?详细步骤解析
*请认真填写需求信息,我们会在24小时内与您取得联系。