热门标签 | 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


推荐阅读
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 展开全部下面的代码是创建一个立方体Thisexamplescreatesanddisplaysasimplebox.#Thefirstlineloadstheinit_disp ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
  • 本文介绍了作者在开发过程中遇到的问题,即播放框架内容安全策略设置不起作用的错误。作者通过使用编译时依赖注入的方式解决了这个问题,并分享了解决方案。文章详细描述了问题的出现情况、错误输出内容以及解决方案的具体步骤。如果你也遇到了类似的问题,本文可能对你有一定的参考价值。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
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社区 版权所有