热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SmartRefreshLayout自定义头部刷新和底部加载

1.添加依赖implementation‘com.scwang.smartrefresh:SmartRefreshLayout:1.0.3’implementation‘com.s

1.添加依赖
implementation ‘com.scwang.smartrefresh:SmartRefreshLayout:1.0.3’
implementation ‘com.scwang.smartrefresh:SmartRefreshHeader:1.0.3’
2.自定义头部

public class MRefreshHeader extends LinearLayout implements RefreshHeader {private ImageView mImage;
// private AnimationDrawable mAnimPull;
// private AnimationDrawable mAnimRefresh;private Animation mAnimRefresh,mAnimPull;/*** 1&#xff0c;构造方法*/public MRefreshHeader(Context context) {this(context, null, 0);}public MRefreshHeader(Context context, &#64;Nullable AttributeSet attrs) {this(context, attrs, 0);}public MRefreshHeader(Context context, &#64;Nullable AttributeSet attrs, int defStyleAttr) {super(context, attrs, defStyleAttr);View view &#61; View.inflate(context, R.layout.m_refresh_header, this);mImage &#61; view.findViewById(R.id.iv_refresh_header);}/*** 2&#xff0c;获取真实视图&#xff08;必须返回&#xff0c;不能为null&#xff09;一般就是返回当前自定义的view*/&#64;NonNull&#64;Overridepublic View getView() {return this;}/*** 3&#xff0c;获取变换方式&#xff08;必须指定一个&#xff1a;平移、拉伸、固定、全屏&#xff09;,Translate指平移&#xff0c;大多数都是平移*/&#64;NonNull&#64;Overridepublic SpinnerStyle getSpinnerStyle() {return SpinnerStyle.Translate;}/*** 4&#xff0c;执行下拉的过程** &#64;param percent* &#64;param offset*/&#64;Overridepublic void onPullingDown(float percent, int offset, int headerHeight, int extendHeight) {if (percent < 1) {mImage.setScaleX(percent);mImage.setScaleY(percent);}}/*** 5&#xff0c;一般可以理解为一下case中的三种状态&#xff0c;在达到相应状态时候开始改变* 注意&#xff1a;这三种状态都是初始化的状态*/&#64;Overridepublic void onStateChanged(&#64;NonNull RefreshLayout refreshLayout, &#64;NonNull RefreshState oldState, &#64;NonNull RefreshState newState) {switch (newState) {//1,下拉刷新的开始状态&#xff1a;下拉可以刷新case PullDownToRefresh:mImage.setImageResource(R.drawable.icon_refresh_line_loading_black);break;//2,下拉到最底部的状态&#xff1a;释放立即刷新case ReleaseToRefresh:
// mImage.setImageResource(R.drawable.anim_pull_end);
// mAnimPull &#61; (AnimationDrawable) mImage.getDrawable();
// mAnimPull.start();mImage.setImageResource(R.drawable.icon_refresh_line_loading_black);break;//3,下拉到最底部后松手的状态&#xff1a;正在刷新case Refreshing:
// mImage.setImageResource(R.drawable.anim_pull_refreshing);
// mAnimRefresh &#61; (AnimationDrawable) mImage.getDrawable();
// mAnimRefresh.start();mImage.setImageResource(R.drawable.icon_refresh_line_loading_black);mAnimRefresh &#61; new RotateAnimation(0f, 360f, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);//ani.setFillAfter(boolean); true停留在旋转后的位置 false复位mAnimRefresh.setFillAfter(!mAnimRefresh.getFillAfter());mAnimRefresh.setDuration(500);mAnimRefresh.setRepeatCount(Animation.INFINITE);mImage.startAnimation(mAnimRefresh);break;default:}}/*** 6&#xff0c;结束下拉刷新的时候需要关闭动画** &#64;param refreshLayout* &#64;param success* &#64;return*/&#64;Overridepublic int onFinish(&#64;NonNull RefreshLayout refreshLayout, boolean success) {
// if (mAnimRefresh !&#61; null && mAnimRefresh.isRunning()) {
// mAnimRefresh.stop();
// }
// if (mAnimPull !&#61; null && mAnimPull.isRunning()) {
// mAnimPull.stop();
// }if (mAnimRefresh !&#61; null && mAnimRefresh.hasStarted()) {mAnimRefresh.cancel();}if (mAnimPull !&#61; null && mAnimPull.hasStarted()) {mAnimPull.cancel();}return 0;}&#64;Overridepublic void onReleasing(float percent, int offset, int headerHeight, int extendHeight) {}&#64;Overridepublic void onStartAnimator(&#64;NonNull RefreshLayout refreshLayout, int height, int maxDragHeight) {}&#64;Overridepublic void setPrimaryColors(int... colors) {}&#64;Overridepublic void onInitialized(&#64;NonNull RefreshKernel kernel, int height, int maxDragHeight) {}&#64;Overridepublic void onHorizontalDrag(float percentX, int offsetX, int offsetMax) {}&#64;Overridepublic boolean isSupportHorizontalDrag() {return false;}}

头部xml


<LinearLayout xmlns:android&#61;"http://schemas.android.com/apk/res/android"xmlns:tools&#61;"http://schemas.android.com/tools"android:layout_width&#61;"match_parent"android:background&#61;"&#64;color/white"android:padding&#61;"5dp"android:gravity&#61;"center"android:layout_height&#61;"wrap_content"><ImageViewandroid:id&#61;"&#64;&#43;id/iv_refresh_header"android:scaleX&#61;"0"android:scaleY&#61;"0"android:translationY&#61;"0dp"android:layout_width&#61;"24dip"android:layout_height&#61;"24dip" />
LinearLayout>

3自定义尾部

public class MRefreshFooter extends LinearLayout implements RefreshFooter {private ImageView mImage;private Animation mAnim;public MRefreshFooter(Context context) {this(context, null, 0);}public MRefreshFooter(Context context, &#64;Nullable AttributeSet attrs) {this(context, attrs, 0);}public MRefreshFooter(Context context, &#64;Nullable AttributeSet attrs, int defStyleAttr) {super(context, attrs, defStyleAttr);View view &#61; View.inflate(context, R.layout.m_refresh_footer, this);mImage &#61; view.findViewById(R.id.iv_refresh_footer);mAnim &#61; AnimationUtils.loadAnimation(getContext(), R.anim.anim_round_rotate);LinearInterpolator linearInterpolator &#61; new LinearInterpolator();mAnim.setInterpolator(linearInterpolator);}&#64;NonNull&#64;Overridepublic View getView() {return this;}&#64;NonNull&#64;Overridepublic SpinnerStyle getSpinnerStyle() {return SpinnerStyle.Translate;}&#64;Overridepublic void setPrimaryColors(int... colors) {}&#64;Overridepublic void onInitialized(&#64;NonNull RefreshKernel kernel, int height, int maxDragHeight) {//控制是否稍微上滑动就刷新kernel.getRefreshLayout().setEnableAutoLoadmore(false);}&#64;Overridepublic void onPullingUp(float percent, int offset, int footerHeight, int extendHeight) {}&#64;Overridepublic void onPullReleasing(float percent, int offset, int footerHeight, int extendHeight) {}&#64;Overridepublic boolean setLoadmoreFinished(boolean finished) {return false;}&#64;Overridepublic void onStartAnimator(&#64;NonNull RefreshLayout refreshLayout, int height, int maxDragHeight) {}&#64;Overridepublic int onFinish(&#64;NonNull RefreshLayout refreshLayout, boolean success) {if(mAnim !&#61; null && mAnim.hasStarted() && !mAnim.hasEnded()){mAnim.cancel();mImage.clearAnimation();}return 0;}&#64;Overridepublic void onHorizontalDrag(float percentX, int offsetX, int offsetMax) {}&#64;Overridepublic boolean isSupportHorizontalDrag() {return false;}&#64;Overridepublic void onStateChanged(&#64;NonNull RefreshLayout refreshLayout, &#64;NonNull RefreshState oldState, &#64;NonNull RefreshState newState) {switch (newState) {case None:case PullToUpLoad:if (mAnim !&#61; null) {mImage.startAnimation(mAnim);}break;case Loading:case LoadFinish:break;case ReleaseToLoad:break;default:}}}

尾部xml


<LinearLayout xmlns:android&#61;"http://schemas.android.com/apk/res/android"android:layout_width&#61;"match_parent"android:layout_height&#61;"wrap_content"android:background&#61;"&#64;color/white"android:gravity&#61;"center"android:orientation&#61;"vertical"android:padding&#61;"5dp"><ImageViewandroid:id&#61;"&#64;&#43;id/iv_refresh_footer"android:layout_width&#61;"20dp"android:layout_height&#61;"20dp"android:src&#61;"&#64;drawable/icon_refresh_line_loading_black" /><TextViewandroid:layout_width&#61;"wrap_content"android:layout_height&#61;"wrap_content"android:layout_marginTop&#61;"10dp"android:text&#61;"底部"android:textSize&#61;"11sp" />
LinearLayout>

4.使用示例


<LinearLayout xmlns:android&#61;"http://schemas.android.com/apk/res/android"android:layout_width&#61;"match_parent"android:layout_height&#61;"match_parent"android:background&#61;"&#64;android:color/white"android:orientation&#61;"vertical"><Viewandroid:id&#61;"&#64;&#43;id/fuzhu_line_v"android:layout_width&#61;"match_parent"android:layout_height&#61;"0.1dp" /><com.scwang.smartrefresh.layout.SmartRefreshLayoutandroid:id&#61;"&#64;&#43;id/content_sfl"android:layout_width&#61;"match_parent"android:layout_height&#61;"match_parent"android:background&#61;"&#64;android:color/white"><com.xxxx.xxx.xxx.MRefreshHeaderandroid:layout_width&#61;"match_parent"android:layout_height&#61;"wrap_content" /><androidx.recyclerview.widget.RecyclerViewandroid:id&#61;"&#64;&#43;id/content_rv"android:layout_width&#61;"match_parent"android:layout_height&#61;"match_parent"android:background&#61;"&#64;android:color/white" /><com.xxx.xxx.xxx.MRefreshFooterandroid:layout_width&#61;"match_parent"android:layout_height&#61;"wrap_content" />com.scwang.smartrefresh.layout.SmartRefreshLayout>LinearLayout>

示例资源图片&#xff1a;
icon_refresh_line_loading_black


推荐阅读
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • YOLOv7基于自己的数据集从零构建模型完整训练、推理计算超详细教程
    本文介绍了关于人工智能、神经网络和深度学习的知识点,并提供了YOLOv7基于自己的数据集从零构建模型完整训练、推理计算的详细教程。文章还提到了郑州最低生活保障的话题。对于从事目标检测任务的人来说,YOLO是一个熟悉的模型。文章还提到了yolov4和yolov6的相关内容,以及选择模型的优化思路。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
  • iOS超签签名服务器搭建及其优劣势
    本文介绍了搭建iOS超签签名服务器的原因和优势,包括不掉签、用户可以直接安装不需要信任、体验好等。同时也提到了超签的劣势,即一个证书只能安装100个,成本较高。文章还详细介绍了超签的实现原理,包括用户请求服务器安装mobileconfig文件、服务器调用苹果接口添加udid等步骤。最后,还提到了生成mobileconfig文件和导出AppleWorldwideDeveloperRelationsCertificationAuthority证书的方法。 ... [详细]
  • 如何在HTML中获取鼠标的当前位置
    本文介绍了在HTML中获取鼠标当前位置的三种方法,分别是相对于屏幕的位置、相对于窗口的位置以及考虑了页面滚动因素的位置。通过这些方法可以准确获取鼠标的坐标信息。 ... [详细]
author-avatar
零落曦_622
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有