SmartRefreshLayout的简单使用

本文介绍了SmartRefreshLayout库的基本使用方法,包括在build.gradle中添加依赖、XML布局文件配置、RecyclerView适配器编写及刷新监听器设置等。SmartRefreshLayout支持多种Header和Footer样式,可实现下拉刷新和上拉加载更多功能。

    之前刷新一直用的是PullToRefreshLayout这个库,感觉有不少坑,直到谷歌出了SmartRefreshLayout,就弃用了PullToRefreshLayout。

   SmartRefreshLayout是一个“聪明”或者“智能”的下拉刷新布局,由于它的“智能”,它不只是支持所有的View,还支持多层嵌套的视图结构。它继承自ViewGroup 而不是FrameLayout或LinearLayout,提高了性能。还集成了各种炫酷的 Header 和 Footer。 SmartRefreshLayout的目标是打造一个强大,稳定,成熟的下拉刷新框架,并集成各种的炫酷、多样、实用、美观的Header和Footer。

这是一个大神写的,如果需要,大家可以去下载,在此先感谢作者

 GitHub地址:https://github.com/scwang90/SmartRefreshLayout   

效果展示:


下面我说一下SmartRefreshLayout的基本使用步骤

1.在 buld.gradle 中添加依赖

compile 'com.scwang.smartrefresh:SmartRefreshLayout:1.1.0-alpha-6'
compile 'com.scwang.smartrefresh:SmartRefreshHeader:1.1.0-alpha-6'//没有使用特殊Header,可以不加这行
compile 'com.android.support:recyclerview-v7:26.0.0-alpha1'

2.在XML布局文件中添加 SmartRefreshLayout

<?xml version="1.0" encoding="utf-8"?>
<com.scwang.smartrefresh.layout.SmartRefreshLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/srl_fresh"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.wen.asyl.pulltorefreshdemo.MainActivity">

    <android.support.v7.widget.RecyclerView
        android:id="@+id/rv_list"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:overScrollMode="never"
        android:background="#fff"/>

</com.scwang.smartrefresh.layout.SmartRefreshLayout>

3.  RecycleAdapter.class

public class RecycleAdapter extends RecyclerView.Adapter<RecycleAdapter.MyViewHolder>{
    private List<String> mDatas;
    private Context mContext;
    private LayoutInflater inflater;


    public RecycleAdapter(Context mContext, List<String> mDatas) {
        this.mContext=mContext;
        this.mDatas=mDatas;
        inflater=LayoutInflater.from(mContext);
    }

    @Override
    public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view = inflater.inflate(R.layout. item,parent, false);
        MyViewHolder holder= new MyViewHolder(view);
        return holder;
    }

    @Override
    public void onBindViewHolder(MyViewHolder holder, int position) {
        holder.tv.setText(mDatas.get(position));
    }

    @Override
    public int getItemCount() {
        return mDatas.size();
    }
    class MyViewHolder extends RecyclerView.ViewHolder {

        TextView tv;

        public MyViewHolder(View view) {
            super(view);
            tv=(TextView) view.findViewById(R.id. tv_item);
        }

    }
    //下面两个方法提供给页面刷新和加载时调用
    public void refresh(List<String> addList) {
        //增加数据
        int position = mDatas.size();
        mDatas.addAll(position, addList);
        notifyDataSetChanged();
    }

}

4.SmartRefreshLayout+RecyclerView

recycleAdapter = new RecycleAdapter(MainActivity.this , mDatas );
LinearLayoutManager layoutManager = new LinearLayoutManager(this);
//设置布局管理器
rvList.setLayoutManager(layoutManager);
//设置为垂直布局,这也是默认的
layoutManager.setOrientation(OrientationHelper.VERTICAL);
//设置Adapter
rvList.setAdapter(recycleAdapter);
//设置 Header 为 贝塞尔雷达 样式
srfresh.setRefreshHeader(new BezierRadarHeader(this).setEnableHorizontalDrag(true));
//设置 Footer 为 球脉冲 样式
srfresh.setRefreshFooter(new BallPulseFooter(this).setSpinnerStyle(SpinnerStyle.Scale));
srfresh.setOnRefreshListener(new OnRefreshListener() {
    @Override
    public void onRefresh(final RefreshLayout refreshlayout) {
        //延时展示,延时2秒
        mHandler.postDelayed(new Runnable() {
            @Override
            public void run() {
                initData();
                recycleAdapter.refresh(mDatas);//刷新加载数据
                refreshlayout.finishRefresh();
            }
        },2000);

    }
});
srfresh.setOnLoadMoreListener(new OnLoadMoreListener() {
    @Override
    public void onLoadMore(final RefreshLayout refreshlayout) {
        mHandler.postDelayed(new Runnable() {
            @Override
            public void run() {
                initData();
                recycleAdapter.refresh(mDatas);
                refreshlayout.finishLoadMore();
            }
        },2000);

    }
});
srfresh.setEnableLoadMore(true);
srfresh.autoRefresh();

以上内容就是我对这个库的一个使用说明,这里介绍的是最常规的用法,当然了,这个库十分强大,还有很多很牛逼的用法,我也在慢慢探索,希望能帮到大家,也希望大家能够多给提提意见。

Demo

https://download.youkuaiyun.com/download/wen_haha/10467012

GitHub

https://github.com/kongkongdaren/PullToReFreshDemo

<think>我们正在使用Kotlin语言和SmartRefreshLayout库来实现下拉刷新和上拉加载的功能。根据引用内容,我们可以构建一个基本的实现方案。 步骤: 1. 添加依赖 2. 在布局文件中添加SmartRefreshLayout和RecyclerView(或其他可滚动视图) 3. 在Activity或Fragment中初始化SmartRefreshLayout,并设置刷新和加载监听器 4. 处理刷新和加载逻辑,并在完成后通知刷新布局 根据引用[4],布局文件示例: 注意:这里使用了ClassicsHeader作为刷新头部,你也可以选择其他头部。 根据引用[2],我们可以利用一些封装来简化分页处理,但这里我们先给出基本的使用方法。 下面是一个简单的实现示例:</think>### Kotlin SmartRefreshLayout 下拉刷新与上拉加载实现教程 在 Kotlin 中使用 SmartRefreshLayout 实现下拉刷新和上拉加载,需完成以下步骤: --- #### 1. **添加依赖** 在 `build.gradle` 中引入库: ```gradle dependencies { implementation 'com.scwang.smart:refresh-layout-kernel:2.0.5' // 核心库 implementation 'com.scwang.smart:refresh-header-classics:2.0.5' // 经典刷新头 implementation 'com.scwang.smart:refresh-footer-classics:2.0.5' // 经典加载尾 } ``` --- #### 2. **布局文件配置** 在 XML 中包裹 `RecyclerView`(或 `ListView`/`ScrollView`): ```xml <com.scwang.smart.refresh.layout.SmartRefreshLayout android:id="@+id/refreshLayout" android:layout_width="match_parent" android:layout_height="match_parent"> <!-- 经典刷新头部 --> <com.scwang.smart.refresh.header.ClassicsHeader android:layout_width="match_parent" android:layout_height="wrap_content"/> <!-- 数据列表 --> <androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent"/> <!-- 经典加载尾部 --> <com.scwang.smart.refresh.footer.ClassicsFooter android:layout_width="match_parent" android:layout_height="wrap_content"/> </com.scwang.smart.refresh.layout.SmartRefreshLayout> ``` > 引用自布局示例[^4] --- #### 3. **Kotlin 代码实现** 在 `Activity`/`Fragment` 中初始化并监听事件: ```kotlin // 初始化 val refreshLayout = findViewById<SmartRefreshLayout>(R.id.refreshLayout) val recyclerView = findViewById<RecyclerView>(R.id.recyclerView) // 设置适配器(示例) val adapter = MyAdapter(dataList) recyclerView.adapter = adapter recyclerView.layoutManager = LinearLayoutManager(this) // 下拉刷新监听 refreshLayout.setOnRefreshListener { loadData(refresh = true) // 刷新数据 } // 上拉加载监听 refreshLayout.setOnLoadMoreListener { loadData(refresh = false) // 加载更多数据 } // 模拟数据加载 private fun loadData(refresh: Boolean) { viewModelScope.launch { delay(1000) // 模拟网络请求 if (refresh) { adapter.clear() adapter.addAll(fetchNewData()) // 获取新数据 refreshLayout.finishRefresh() // 结束刷新 } else { adapter.addAll(fetchMoreData()) // 追加数据 refreshLayout.finishLoadMore() // 结束加载 } } } ``` --- #### 4. **高级配置** - **自动加载更多**: ```kotlin refreshLayout.setEnableAutoLoadMore(true) // 滚动到底部自动加载 ``` - **自定义样式**: 修改 `ClassicsHeader`/`ClassicsFooter` 的文本、动画资源。 - **空数据/错误处理**: 在加载完成后检查数据量,调用 `refreshLayout.finishLoadMoreWithNoMoreData()` 提示无更多数据。 --- #### 注意事项 1. 确保在数据加载完成后调用 `finishRefresh()` 或 `finishLoadMore()`,否则视图会持续等待。 2. 若需预加载(用户无感知加载),可结合 `setOnLoadMoreListener` 和 `setEnableAutoLoadMore(true)` 实现[^3]。 3. 网络请求失败时,调用 `refreshLayout.finishLoadMore(false)` 标记加载失败。 > 提示:封装通用基类(如 `BaseRefreshFragment`)可简化分页逻辑[^2]。
评论 5
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值