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())
    }
}
相关推荐
草莓熊Lotso1 小时前
脉脉独家【AI创作者xAMA】| 开启智能创作新时代
android·java·开发语言·c++·人工智能·脉脉
李坤林1 小时前
Android Binder详解【5】 ServiceManager
android·binder
Ya-Jun1 小时前
Android 扫雷游戏项目设计报告
android·游戏
_李小白1 小时前
【Android 性能分析】第五天:Perfetto UI分析CPU
android·ui
MindCareers2 小时前
Beta Sprint Day 1-2: Alpha Issue Fixes Initiated + Mobile Project Setup
android·c语言·数据库·c++·qt·sprint·issue
龚礼鹏2 小时前
Android应用程序 c/c++ 崩溃排查流程三——ndk-stack工具使用
android
zhengfei6112 小时前
CVE-2025-13156 - Vitepos WooCommerce 的销售(POS) 系统漏洞
android
奥陌陌2 小时前
自定义view, 图片右上角显示数字
android
TheNextByte12 小时前
将照片从Mac传输到Android 7 种可行方法
android·macos·gitee
青莲8432 小时前
Java并发编程基础与进阶(线程·锁·原子类·通信)
android·前端·面试