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())
    }
}
相关推荐
恋猫de小郭1 小时前
2026,Android Compose 终于支持 Hot Reload 了,但是收费
android·前端·flutter
RainyJiang9 小时前
谱写Kotlin协程面试进行曲-进阶篇(第二乐章)
面试·kotlin·android jetpack
mygljx12 小时前
MySQL 数据库连接池爆满问题排查与解决
android·数据库·mysql
xinhuanjieyi13 小时前
ruoyimate导入sql\antflow\bpm_init_db.sql报错
android·数据库·sql
闲猫14 小时前
基于RABC的权限控制设计
android
星霜笔记17 小时前
GitMob — 手机端 GitHub 管理工具
android·kotlin·github·android jetpack
LiuYaoheng18 小时前
问题记录:Android Studio Low memory
android·ide·android studio
独隅18 小时前
Python 标准库 (Standard Library) 全面使用指南
android·开发语言·python
always_TT19 小时前
strlen、strcpy、strcat等常用字符串函数
android
qqty121719 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql