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())
    }
}
相关推荐
冬奇Lab1 天前
Android触摸事件分发、手势识别与输入优化实战
android·源码阅读
城东米粉儿1 天前
Android MediaPlayer 笔记
android
Jony_1 天前
Android 启动优化方案
android
阿巴斯甜1 天前
Android studio 报错:Cause: error=86, Bad CPU type in executable
android
张小潇1 天前
AOSP15 Input专题InputReader源码分析
android
_小马快跑_1 天前
Kotlin | 协程调度器选择:何时用CoroutineScope配置,何时用launch指定?
android
_小马快跑_1 天前
Kotlin | 从SparseArray、ArrayMap的set操作符看类型检查的不同
android
_小马快跑_1 天前
Android | 为什么有了ArrayMap还要再设计SparseArray?
android
_小马快跑_1 天前
Android TextView图标对齐优化:使用LayerList精准控制drawable位置
android
_小马快跑_1 天前
Kotlin协程并发控制:多线程环境下的顺序执行
android