美文网首页Android潜修者三方Android技术
SwipeToLoadLayout--小白也能轻松定制自己的刷新

SwipeToLoadLayout--小白也能轻松定制自己的刷新

作者: dongjunkun | 来源:发表于2015-11-28 21:06 被阅读18698次

刚开始接触android的时候,就想着如果能定制一款属于自己的刷新效果,肯定会是一件很酷的事情,当然了,github上已经有了很多很炫酷的刷新效果,各种漂亮,但在项目中总要讲究个实用性,有些刷新效果是不错,但在实战中就会显得很不搭,无赖只能舍弃,XListView实用,PullToRefresh也实用,用了这么久,是真不想用,在当时是很酷,可这些项目也早就没人维护,刷新效果有些过时,修改起来也不是那么容易,项目中经常要赶进度,so,也一直将就着用,google 提供的SwipeRefreshLayout效果也不赖,但却很局限,样式局限,子布局还一定得是可以滑动的布局(如ListView,ScrollView),还没提供上拉加载的效果,要用还得自己写,还有一点不知道google怎么搞的,SwipeRefreshLayout居然和RecyclerView冲突(连续下拉,刷新样式会一团糟,还会卡住),自家控件还弄成这样,真是的。说了那么一堆,来看看今天的主角SwipeToLoadLayout,献上两张截图:

未标题-1.jpg

刷新框架那么多,为什么我选择了SwipeToLoadLayout

  • 首先看效果,框架中帮我们实现了几个主流的刷新效果,Twitter style,JD style,google style,Yalantis style,demo也下载下来看了,真不错,还支持各种自定义,自定义头部和尾部,头部还分classic,above,blow,scale四种类型,还有自动刷新的效果,体验也很流畅。

  • 再看代码,刷新,加载各一个接口实现,头部和尾部也都是用接口实现,遵循设计模式的依赖倒转原则原则(针对抽象而不是针对具体编程),所以才能具备那么高可塑性,我们要做的就是实现接口里面的内容就可以轻松写一个刷新效果,就像使用baseAdapter一样,无论什么数据,什么样式,都可以轻松实现。

  • 接着看功能,支持各种View和ViewGroup(ListView,ScrollView,RecyclerView,GridView,WebView,Linearlayout,RelativeLayout,FrameLayout,ImageView,TextView等)的刷新和加载,还支持自动刷新,手动刷新,自动加载,手动加载,禁止刷新,禁止加载等操作,完全满足需求。

最后,说的这么好,有没有经过测试呢?当然了,口说无凭,带大家实现一个。

通过SwipeToLoadLayout实现一个刷新加载的效果

1、如何集成

Step 1. Add the JitPack repository in your build.gradle at the end of repositories:

repositories {
    maven { url "https://jitpack.io" }
}

Step 2. Add the dependency in the form

dependencies {
    compile 'com.github.Aspsine:SwipeToLoadLayout:v1.0.0'
}

2,开始自定义刷新效果

swipeToLoadLayout提供了一套接口,刷新的头部自定义一个View实现SwipeTrigger和SwipeRefreshTrigger就行了,刷新的尾部自定义一个View实现SwipeLoadMoreTrigger和SwipeTrigger,头部实现代码:

public class CustomRefreshHeadView extends TextView implements SwipeRefreshTrigger, SwipeTrigger {
    public CustomRefreshHeadView(Context context) {
        super(context);
    }

    public CustomRefreshHeadView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public CustomRefreshHeadView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    @Override
    public void onRefresh() {
        setText("正在拼命加载数据...");
    }

    @Override
    public void onPrepare() {

    }

    @Override
    public void onSwipe(int i, boolean b) {
        setText("释放刷新");

    }

    @Override
    public void onRelease() {


    }

    @Override
    public void complete() {
        setText("刷新成功");
    }

    @Override
    public void onReset() {

    }
}

Xml中使用

注意,swipetoloadlayout中布局包裹的View id是指定的,不能乱改,否则找不到<item name="swipe_target" type="id" />刷新目标
<item name="swipe_refresh_header" type="id" />刷新头部
<item name="swipe_load_more_footer" type="id" />刷新尾部

<?xml version="1.0" encoding="utf-8"?>
<com.aspsine.swipetoloadlayout.SwipeToLoadLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/swipeToLoad"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.yyydjk.swipetorefreshdemo.MainActivity">

    <com.yyydjk.swipetorefreshdemo.CustomRefreshHeadView
        android:id="@+id/swipe_refresh_header"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:padding="20dp" />

    <TextView
        android:id="@+id/swipe_target"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@color/colorPrimary"
        android:gravity="center"
        android:text="Hello World!" />
</com.aspsine.swipetoloadlayout.SwipeToLoadLayout>

代码中调用

CustomRefreshHeadView refreshHeadView = new CustomRefreshHeadView(this);
refreshHeadView.setPadding(20,20,20,20);
refreshHeadView.setGravity(Gravity.CENTER);
refreshHeadView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,
                ViewGroup.LayoutParams.WRAP_CONTENT));
swipeToLoadLayout.setRefreshHeaderView(refreshHeadView);

就这么简单,看下演示效果,做的丑了点,以后有时间弄个精致点的


swipeToRefresh.gif

就这么简单,大伙可以试试,更多用法查看原作者项目demo。

希望大家多多关注我,好东西,分享才有价值

相关文章

  • SwipeToLoadLayout--小白也能轻松定制自己的刷新

    刚开始接触android的时候,就想着如果能定制一款属于自己的刷新效果,肯定会是一件很酷的事情,当然了,githu...

  • Android中SwipeToLoadLayout的使用

    SwipeToLoadLayout轻松定制自己的刷新效果,且子布局不在局限只是可以滑动的布局(如ListView,...

  • 小白也能轻松学画画?

    我听很多人跟我说:“画画,我没这个天赋啊,我不行啊。”“画画我一没基础二没审美,怎么画啊?”“天呐,我这画的是什么...

  • 资产配置,小白也能轻松进行

    我曾经在雪球瞎逛时看过一句这样的一句话:“资产配置决策是一个只有投资视野很旷阔的人才会常常遇到并且思考的问题”...

  • 小白也能轻松上手的Prometheus教程

    这篇文章将承接此前关于使用Prometheus配置自定义告警规则的文章。在本文中,我们将demo安装Prometh...

  • PPT小白也能轻松上手的九款神器!

    作为一个PPT爱好者,我来分享一下提升PPT制作效率的9款神器,简单实用小白也可以轻松上手,用过一次就再也离不开它...

  • 五个常用的办公技巧,谁用谁说好

    办公技巧可以让我们办公更轻松,效率更高,今天给大家分享五个办公实用小技巧,就算是新手小白也能轻松的掌握。 1、快速...

  • 道道道

    最近家里装修,所有家具定制。 我是造价师,又经手过装修项目,因此这些家具单位我能轻松寻到工程价也能付钱让他们直接做...

  • 007+红尘听雪+释若公式写作+原创金句

    第一题:写一篇总结文,用自己的话,对写作公式进行总结,要求:突出亮点。 掌握写作公式,小白也能轻松变大神 阅读量太...

  • 刷新控件实现

    刷新控件在项目中还是用的比较多的,可以依赖第三方框架做,但是如果自己的公司的刷新控件比较的特别,还是最好自己定制一...

网友评论

  • 西北狼神:其实我想说,这个库真的很烂。:sob: 不要喷我。:joy:
    dongjunkun:@西北狼神 这个不是,之前一直在用,现在换了SmartRefreshLayout,我想说开源并维护一个库需要花费大量的精力,还是不要随便喷的好:blush:
    西北狼神:@dongjunkun :cold_sweat: 难道是你自己的库:stuck_out_tongue_winking_eye:
    dongjunkun:@西北狼神 好久没维护了
  • 㷣㷣:SwipeToLoadLayout 在使用时 里面嵌套ScrollView以后 布局就都不显示了 这是为什么
  • 5f3dd95ab0ee:支持滑动到底部自动加载更多吗
    1da18fa1a97a:做了个常识,recylerview自己监听是否滑到底部,然后设置这个开源项目的setLoadingMore 为true。。。绕弯子了
    1da18fa1a97a:我也在找这个。。
  • 小名坎坎:作者你好,头部底部不一样风格怎么办
  • pdog18:刷新的控件id居然是固定的,我也是无语了?为什么要设计成这样呢? 如果是为了获取布局 ,直接getChildAt(1) 不行吗?真的不知道为什么
  • vanchi:刷新的时候,它的header是停留在顶部的,当向上滑动的时候,隐藏头部,请问该如何操作
    ztftrue:setLoadingMore(false);
    恒等式古怪:swipToLoadLayout.setEnable(false)就可以啦
    dongjunkun:@V_neymarjr 可以想原作者提这个建议吧,确实一直固定体验也一点点的影响
  • f464bc828e7d:捉襟见肘
  • 捡淑:马克
  • Zcp_ing:我在使用swipetoloadlayout+recyclerview的时候,遇见一个问题,作者知道吗?
    Attempt to invoke virtual method 'boolean android.view.View.canScrollVertically(int)' on a null object reference
    ztftrue:@dongjunkun 嗯
    dongjunkun: @ztftrue id是指定的,不能改
    ztftrue:控件名字必须是它的
  • 07932fdb3eb7:他这个东西我也用了 但是 不像是一般的那个刷新一样 ,他是刷新后停留在顶部的, 如果做到像是普通的刷新时可以收回的 怎么搞 ,搞了好久 没能搞定
    617efcea5301:@恩恩恩么 你要在你的刷新完成时间里面写各种控件的显隐控制啊
  • Dear_HS:与SmartTabLayout不兼容
  • a15111724a2f:作者你好,能加你QQ聊下吗,我用SwipeToLoadLayout老是跑不起来,你那里有写哈的Demo能发个吗,我的QQ:258417738

本文标题:SwipeToLoadLayout--小白也能轻松定制自己的刷新

本文链接:https://www.haomeiwen.com/subject/lsodhttx.html