AsyncImage在LazyColumnKotlinCompose中的使用
创始人
2024-09-21 04:30:52
0
  1. 导入必要的Compose库 implementation "androidx.compose.foundation:foundation:1.0.0-rc02"implementation "androidx.compose.material:material:1.0.0-rc02"

  2. 在需要使用AsyncImage的地方,引入 androidx.compose.foundation.lazy.LazyColumn,例如:

LazyColumn {
    itemsIndexed(images) { _, imageUrl ->
        AsyncImage(
            modifier = Modifier.fillMaxWidth(),
            contentScale = ContentScale.Crop,
            content = {
                CoilImage(
                    data = imageUrl,
                    contentDescription = null,
                    contentScale = ContentScale.Crop,
                    fadeIn = true,
                    loading = {
                        //显示加载中
                        Box(
                            Modifier
                                .fillMaxSize()
                                .background(Color.LightGray)
                        ) {
                            CircularProgressIndicator(Modifier.align(Alignment.Center))
                        }
                    }
                )
            }
        )
    }
}

这里使用了Coil作为图片加载库。在加载图片时,AsyncImage会显示加载中的进度条。

注意:由于还处于Composable函数编写的过程中,记得使用@Preview注解提供预览效果。

@Preview(showBackground = true)
@Composable
fun PreviewAsyncImage() {
    MyTheme {
        LazyColumn {
            itemsIndexed(images) { _, imageUrl ->
                AsyncImage(
                    modifier = Modifier.fillMaxWidth(),
                    contentScale = ContentScale.Crop,
                    content = {
                        CoilImage(
                            data = imageUrl,
                            contentDescription = null,
                            contentScale = ContentScale.Crop,
                            fadeIn = true,
                            loading = {
                                //显示加载中
                                Box(
                                    Modifier
                                        .fillMaxSize()
                                        .background(Color.LightGray)
                                ) {
                                    CircularProgressIndicator(Modifier.align(Alignment.Center))
                                }
                            }
                        )
                    }
                )
            }
        }
    }
}

其中MyTheme提供了样式和颜色,可以在Theme.kt文件中定义。

@Composable
fun MyTheme(content: @Composable () -> Unit) {
    MaterialTheme(
        colors = Colors,
        typography = Typography,
        content = content

相关内容

热门资讯

第6分钟实锤!德扑之星ai代打... 第6分钟实锤!德扑之星ai代打(wepower德州)竟然是有挂(详细辅助透明教程);亲,关键说明,德...
6分钟实锤!智星德州菠萝(德扑... 6分钟实锤!智星德州菠萝(德扑)竟然是有挂(详细辅助大神讲解)小薇(透视辅助)致您一封信;亲爱智星德...
第二分钟实锤!智星德州菠萝偷偷... 第二分钟实锤!智星德州菠萝偷偷看牌功能(来玩德州app)真是是真的有挂(详细辅助可靠教程)1、下载好...
第2分钟实锤!德州免费辅助神器... 第2分钟实锤!德州免费辅助神器app(德州wepower)一贯是真的有挂(详细辅助专业教程);1、游...
第5分钟实锤!德扑之星辅助器购... 第5分钟实锤!德扑之星辅助器购买(wepower德州)一直存在有挂(详细辅助2025新版教程)1、打...
八分钟实锤!德州之星外挂(德州... 八分钟实锤!德州之星外挂(德州)本来存在有挂(详细辅助解密教程)一、德州之星外挂AI软件牌型概率发牌...
第六分钟实锤!德州微扑克辅助(... 第六分钟实锤!德州微扑克辅助(德州app)都是存在有挂(详细辅助软件教程)德州微扑克辅助是一种具有地...
第4分钟实锤!智星德州菠萝偷偷... 第4分钟实锤!智星德州菠萝偷偷看牌功能(德州之星)本来有挂(详细辅助系统教程)1、玩家可以在智星德州...
两分钟实锤!德州免费辅助神器a... 两分钟实锤!德州免费辅助神器app(线上wpk德州)其实是有挂(详细辅助教你攻略)1、让任何用户在无...
七分钟实锤!德州微扑克辅助(来... 七分钟实锤!德州微扑克辅助(来玩德州app)本来有挂(详细辅助2025新版)一、德州微扑克辅助AI软...