android compose PullToRefreshAndLoadMore 下拉刷新 + 上拉加载更多 使用

android compose PullToRefreshAndLoadMore 下拉刷新 + 上拉加载更多 使用

复制代码
/**
 * Author : wn
 * Email : maoning20080809@163.com
 * Date : 2026/1/6 20:23
 * Description : 下拉刷新 + 上拉加载更多
 */
class PullToRefreshActivity : ComponentActivity(){

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

        setContent {
            testPullToRefreshAndLoadMoreDemo()
        }
    }

    @Preview
    @Composable
    private fun testPullToRefreshAndLoadMoreDemo(){
        var refreshing by remember { mutableStateOf(false) }
        var loadingMore by remember { mutableStateOf(false) }

        var items by remember { mutableStateOf<ArrayList<String>>(arrayListOf()) }
        var page by remember { mutableStateOf(1) }

        //初始化加载数据
        LaunchedEffect(Unit) {
            items = loadData(page)
        }

        //下拉刷新
        LaunchedEffect(refreshing) {
            if(refreshing){
                delay(1500)
                page = 1
                items = loadData(page)
                refreshing = false
            }
        }

        //上拉加载更多
        LaunchedEffect(loadingMore) {
            if(loadingMore){
                delay(1500)
                page++
                val newItemList = loadData(page)
                items.addAll(newItemList)
                loadingMore = false
            }
        }

        Text(text = "PullToRefreshAndLoadMore 下拉刷新 下拉加载更多", color = Color.Red)
        SwipeRefresh(state = rememberSwipeRefreshState(refreshing),
            onRefresh = {
                refreshing = true
            }) {
            LazyColumn() {
                items(items.size){index ->
                    Text(text = items[index], modifier = Modifier.fillMaxWidth().padding(16.dp))
                    //检测是否滚动到底部
                    if(index == items.size -1 && !loadingMore && !refreshing){
                        loadingMore = true
                    }
                }

                //显示加载更多指示器
                if(loadingMore){
                    item{
                        Box(modifier = Modifier.fillMaxWidth().padding(16.dp),
                            contentAlignment = Alignment.Center){
                            CircularProgressIndicator()
                        }
                    }
                }
            }
        }
    }

    private suspend fun loadData(page : Int) : ArrayList<String>{
        //模拟网络请求
        //delay(500)
        return List(20){"Item ${(page - 1) * 20 + it + 1}"}.toCollection(ArrayList())
    }
}
相关推荐
常利兵4 小时前
2026年,Android开发已死?不,它正迎来黄金时代!
android
Risehuxyc4 小时前
备份三个PHP程序
android·开发语言·php
Doro再努力14 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim
Daniel李华14 小时前
echarts使用案例
android·javascript·echarts
做人不要太理性15 小时前
CANN Runtime 运行时组件深度解析:任务调度机制、存储管理策略与维测体系构建逻辑
android·运维·魔珐星云
我命由我1234516 小时前
Android 广播 - 静态注册与动态注册对广播接收器实例创建的影响
android·java·开发语言·java-ee·android studio·android-studio·android runtime
朗迹 - 张伟16 小时前
Tauri2 导出 Android 详细教程
android
lpruoyu17 小时前
【Android第一行代码学习笔记】Android架构_四大组件_权限_持久化_通知_异步_服务
android·笔记·学习
独自破碎E18 小时前
【BISHI15】小红的夹吃棋
android·java·开发语言
李堇21 小时前
android滚动列表VerticalRollingTextView
android·java