BGARefreshLayout的简单使用

本文介绍了一个新的上拉下拉刷新库BGARefreshLayout的使用方法,包括如何在项目中引入依赖、设置刷新样式及处理刷新逻辑等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一个新的上拉下拉刷新的库工程

需要依赖,github可以下载

compile 'com.android.support:recyclerview-v7:24.2.1'
compile 'com.nineoldandroids:library:2.4.0'

1.将内容用BGARefreshLayout包裹

(高度设置为权重是因为上拉加载的时候必须设置设置这个权重,)

<cn.bingoogolapple.refreshlayout.BGARefreshLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/bgarefresh">
        <TextView
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"
            android:layout_gravity="center"
            android:text="可以放任何控件"
            android:id="@+id/text"/>


    </cn.bingoogolapple.refreshlayout.BGARefreshLayout>

2.设置头布局就是刷新的样式

 //设置头部特效参数1 上下文 参数2 是否支持加载更多
        BGANormalRefreshViewHolder bgaNormalRefreshViewHolder = new BGANormalRefreshViewHolder(this, true);
        bgaRefreshLayout.setRefreshViewHolder(bgaNormalRefreshViewHolder);

3.处理刷新的逻辑

//处理刷新的逻辑,也可以说是监听,也可以说是回调,反正就是一个下拉和上拉的逻辑在这里
        bgaRefreshLayout.setDelegate(new BGARefreshLayout.BGARefreshLayoutDelegate() {
            @Override
            public void onBGARefreshLayoutBeginRefreshing(BGARefreshLayout refreshLayout) {
            textView.setText(new Date().toLocaleString());
                //关闭刷新的状态
                bgaRefreshLayout.endRefreshing();
            }
        //上拉 return  true 才会有更多页面,默认是false
            @Override
            public boolean onBGARefreshLayoutBeginLoadingMore(BGARefreshLayout refreshLayout) {
                textView.setText("加载更多"+new Date().toLocaleString());

                return true;
            }
        });

可以写一个工具类来替换下拉刷新的样式

public class HeaderUtil {
    //设置旋转箭头的特效
    public static BGARefreshViewHolder getNormalHeader(Context context
    ) {
        return new BGANormalRefreshViewHolder(context, true);

    }
// 获取的是粘性效果
    public static BGARefreshViewHolder getStickyHeader(Context context) {
        BGAStickinessRefreshViewHolder holder = new BGAStickinessRefreshViewHolder(context, true);
        holder.setRotateImage(R.mipmap.bga_refresh_stickiness);
        holder.setStickinessColor(R.color.colorAccent);
        return holder;

    }
    public static BGARefreshViewHolder getWaveHeader(Context context
    ){
        BGAWaveStyleRefreshViewHolder header=new BGAWaveStyleRefreshViewHolder(context,true);//1.上下文 2.是否支持加载更多

        //水波颜色
        header.setUltimateColor(R.color.colorAccent);
        //图片
        header.setOriginalImage(R.mipmap.bga_refresh_moooc);

        return null;

    }
    public static BGARefreshViewHolder getMeituanHeader(Context context){
        BGAMeiTuanRefreshViewHolder holder = new BGAMeiTuanRefreshViewHolder(context, true);
       //设置小幅度拉动图片
        holder.setPullDownImageResource(R.mipmap.bga_refresh_mt_pull_down);
   //设置下拉     holder.setChangeToReleaseRefreshAnimResId(R.drawable.pulling);
     //设置刷新时的图片,我这里采用的是帧动画   holder.setRefreshingAnimResId(R.drawable.refreshing);
        return holder;
    }

}
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、付费专栏及课程。

余额充值