小撸BGARefreshView 自定义控件

在Github瞎逛时发现开源的BGARefreshView自定义控件,趁着有空就学习学习,效果还不错额,看下面效果图

I 开源项目的地址

https://github.com/bingoogolapple/BGARefreshLayout-Android

II 用法

添加gradle依赖

dependencies 
{
    compile 'com.android.support:recyclerview-v7:latestVersion'
    compile 'com.nineoldandroids:library:2.4.0'
    compile 'cn.bingoogolapple:bga-refreshlayout:1.1.6'
}

下面是xml的布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:orientation="vertical" android:layout_width="match_parent"
        android:layout_height="match_parent">

        <cn.bingoogolapple.refreshlayout.BGARefreshLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/bga_refresh"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

            <!--只能有一个子控件,必须设置权重-->
            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="0dp"
                android:layout_weight="1"
                android:orientation="vertical">

                <TextView
                    android:layout_width="match_parent"
                    android:text="仿mooc网的下拉刷新"
                    android:padding="5dp"
                    android:gravity="center"
                    android:textSize="15sp"
                    android:layout_height="100dp" />
                <TextView
                    android:layout_width="match_parent"
                    android:text="仿mooc网的下拉刷新1"
                    android:padding="5dp"
                    android:gravity="center"
                    android:textSize="15sp"
                    android:layout_height="100dp" />
                <TextView
                    android:layout_width="match_parent"
                    android:text="仿mooc网的下拉刷新2"
                    android:padding="5dp"
                    android:gravity="center"
                    android:textSize="15sp"
                    android:layout_height="100dp" />


           </LinearLayout>
    </cn.bingoogolapple.refreshlayout.BGARefreshLayout>
</LinearLayout>

下面是具体的实现代码

/**
* Created by WYK on 2016/11/9.
*/
public class Wfragment extends Fragment {

        private BGARefreshLayout refreshLayout;
        private Handler mHandler = new Handler();

        @Nullable
        @Override
        public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
            View rootView = inflater.inflate(R.layout.fragment_w_refresh, container, false);
            refreshLayout = findView(rootView, R.id.bga_refresh);
            initRefresh();                                      

            return rootView;
        }
        /**初始化刷新加载控件*/
        private void initRefresh(){
            refreshLayout.setDelegate(new BGARefreshLayout.BGARefreshLayoutDelegate() {             //代理监听
                @Override
                public void onBGARefreshLayoutBeginRefreshing(final BGARefreshLayout refreshLayout) {       //开始下拉刷新
                    mHandler.postDelayed(new Runnable() {
                        @Override
                        public void run() {
                            refreshLayout.endRefreshing();
                        }
                    },1500);
                }
                @Override
                public boolean onBGARefreshLayoutBeginLoadingMore(final BGARefreshLayout refreshLayout) {   //开始上拉加载
                    mHandler.postDelayed(new Runnable() {
                    @Override
                    public void run() {
                        refreshLayout.endLoadingMore();
                    }
                },1500);
                return true;           //返回true才会显示加载更多的提示,处理更多数据的显示进度框
            }
            });

            BGAMoocStyleRefreshViewHolder refreshViewHolder = new BGAMoocStyleRefreshViewHolder(getActivity(), true);
          //  WYKMoocStyleRefreshViewHolder refreshViewHolder = new WYKMoocStyleRefreshViewHolder(getActivity(),true);        //自定义的
            refreshViewHolder.setOriginalImage(R.mipmap.bga_refresh_moooc);
            refreshViewHolder.setUltimateColor(R.color.colorAccent);
            refreshViewHolder.setLoadMoreBackgroundColorRes(R.color.colorPrimary);
            refreshLayout.setRefreshViewHolder(refreshViewHolder);
        }

        public <VT> VT findView(View rootView,int resId){
            VT t = (VT) rootView.findViewById(resId);
            return t;
        }

}

上面是具体的仿慕课网下拉刷新的效果实现,当然BGARefreshView自定义控件还有其他效果,实现代码大体相同,只要传入实现的不同的RefreshViewHolder即可实现,看看下面的效果图;

仿慕课网下拉刷新
仿美团下拉刷新


III 罗列各个主要类的简解

BGARefreshViewHolder

这是一个抽象类,抽取了刷新加载控件的公共属性和方法,主要有下拉控件、刷新控件、背景颜色及drawable设置、下拉的默认高度及控制等等,该类的具体体现是在与BGARefreshLayout的关联中,可以看到该类的setRefreshLayout方法,作用是供BGARefreshLayout调用,传入BGARefreshLayout对象,结合这两个类的查看,可以看到BGARefreshViewHolder这个类主要提供了初始化控件的方法,供BGARefreshLayout对象在各个生命周期及方法里调用,可以将BGARefreshViewHolder看成是刷新控件布局的持有者,对其基本的初始化配置。


WYKMoocStyleRefreshViewHolder/BGAMeiTuanRefreshViewHolder/BGAMoocStyleRefreshViewHolder/BGANormalRefreshViewHolder/BGAStickinessRefreshViewHolder

上面的都是继承自BGARefreshViewHolder抽象类的子类,分别为类似慕课网的下拉刷新效果控件(仿慕课网下拉刷新控件的基础上改的)、仿美团下拉刷新控件、仿慕课网下拉刷新控件、仿新浪微博下拉刷新控件、黏性下拉刷新风格控件;主要实现的获取头部刷新控件的方法,毕竟各个下拉控件的刷新效果都不一,还有一些子类独有的方法,比如设置下拉刷新控件的图标/文字等等,每个控件的效果都不一,所以将这些定义为子类自有的方法。


BGARefreshLayout

继承自LinearLayout布局,实现自定义刷新加载控件,在定义的xml布局中使用,在BGARefreshLayout里只能设置一个子控件,还必须设置子控件的权重为1,不然报错;一般需要设置多个控件的情况下,可设置1布局控件中嵌套多个需求中的控件,例如设置一个子控件为ScrollView,ScrollView里再嵌套线性布局LinearLayout,在其里面再嵌套其它子控件。


BGAMoocStyleRefreshView/BGAMeiTuanRefreshView/BGAStickinessRefreshView

三种下拉刷新的自定义控件,分别为仿慕课网下拉刷新、美团下拉刷新、黏性下拉刷新风格控件;有的继承自View,有的继承自相对布局,具体得看布局的方式;

  • BGAMoocStyleRefreshView继承自View,在仿慕课网下拉刷新的自定义控件的类里,其主要工作是对下拉刷新图片进行绘制;主要看看该类中View的onMeasure和onDraw这两个方法;

  • BGAMeiTuanRefreshView继承自RelativeLayout布局,实现仿美团下拉效果的该类中,其主要工作是针对下拉状态/释放刷新/刷新状态/结束状态/ 这四个状态下的图片效果进行提供方法出去给外类进行设置,本身对其进行处理;

  • BGAStickinessRefreshView继承自View,黏性下拉刷新的效果,主要针对View的测量与绘制以及一些动画和贝塞尔曲线的绘制。


BGAStickyNavLayout

效果:上拉隐藏的效果,必须保证该布局下只能有三个控件,在上拉的过程中,当第一位置的控件完全隐藏时,处于第二位置的控件会出现悬浮在顶部的效果;
>
大致实现:BGAStickyNavLayout继承自LinearLayout,主要是对子View的测量以及滑动事件的处理;


记录

  • BGAStickyNavLayout控件设置RefreshLayout,实现下拉刷新效果时,并未看到效果,猜测作者可能暂未实现;
  • BGAStickyNavLayout中第三个子控件往下拉时,第二个控件时常不会移下来,仍处于悬浮的状态。
  • 具体的代码细节实现还得慢慢摸索,本文只是大致略过

附言:如有侵权,请告知删除,谢谢

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
BGARefreshLayout包含多种下拉刷新效果、上拉加载更多、可配置自定义头部广告位 。效果图:      目前已经实现了四种下拉刷新效果:新浪微博下拉刷新风格(可设置各种状态是的文本,可设置整个刷新头部的背景)慕课网下拉刷新风格(可设置其中的logo和颜色成自己公司的风格,可设置整个刷新头部的背景)美团下拉刷新风格(可设置其中的图片和动画成自己公司的风格,可设置整个刷新头部的背景)类似qq好友列表黏性下拉刷新风格(三阶贝塞尔曲线没怎么调好,刚开始下拉时效果不太好,可设置整个刷新头部的背景)一种上拉加载更多效果新浪微博上拉加载更多(可设置背景、状态文本)开发者也可以继承BGARefreshViewHolder这个抽象类,实现相应地抽象方法做出格式各样的下拉刷新效果 【例如实现handleScale(float scale, int moveYDistance)方法,根据scale实现各种下拉刷新动画】和上拉加载更多特效,可参考 BGAMoocStyleRefreshViewHolder、BGANormalRefreshViewHolder、 BGAStickinessRefreshViewHolder、BGAMeiTuanRefreshViewHolder的实现方式。目前存在的问题当配置自定义头部广告位可滚动时,内容区域和广告位还不能平滑过度。当BGAStickyNavLayout中嵌套RecyclerView或AbsListView,并且第一页的最后一个item刚好在最底部时,加载更多视图会悬浮在最后一个item上面正在刷新或加载更多时,用户上下滑动不会让下拉刷新视图和加载更多视图跟着滑动
基于SwipeRefreshLayout下拉刷新、上拉加载。支持所有的AbsListView、RecycleView 特点  在 layout 中使用,支持 AbsListView 所有的xml属性  支持自动下拉刷新,什么用呢?比如进入界面时,只需要调用 autoRefresh() 方法即可,同时下拉刷新回调函数将会被调用。  上拉加载支持自定义 View 或设置加载文字、动画  轻松设置 Adapter 空数据视图,默认为 TextView 支持更文字,也可自定义 View  对于简单的界面,如只有 ListView 可以继承 app 包中 Fragment 轻松搞定 效果图 使用 仔细看 listSelector 属性,效果见 sample <com.mylhyl.prlayout.SwipeRefreshListView xmlns:android="http://schemas.android.com/apk/res/android"     xmlns:tools="http://schemas.android.com/tools"     android:id="@ id/swipeRefresh"     android:layout_width="match_parent"     android:layout_height="match_parent"     android:listSelector="@drawable/selector_list"     tools:context=".app.ListViewXmlFragment" /> 设置上拉加载,更多方法见 IFooterLayout         IFooterLayout footerLayout = swipeRefreshListView.getFooterLayout();         footerLayout.setFooterText("set自定义加载");         footerLayout.setIndeterminateDrawable(getResources().getDrawable(R.drawable.footer_progressbar)); 自定义adapter空数据视图         ImageView emptyView = new ImageView(getContext());         emptyView.setImageResource(R.mipmap.empty);         swipeRefreshGridView.setEmptyView(emptyView); 或         swipeRefreshListView.setEmptyText("数据呢?"); 使用Gradle构建时添加一下依赖即可: compile 'com.mylhyl:pullrefreshlayout:1.0.0' QQ交流群:435173211

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值