欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android Jetpack Compose實現(xiàn)列表吸頂效果

 更新時間:2022年02月22日 16:33:10   作者:九狼  
安卓傳統(tǒng)的Recyclerview打造懸浮頭部StickyHeader的吸頂效果,十分麻煩,而在Compose中就簡單多了。因此,本文將采用Jetpack Compose實現(xiàn)列表吸頂效果,需要的可以參考一下

安卓傳統(tǒng)的 Recyclerview 打造懸浮頭部StickyHeader的吸頂效果,十分麻煩,而在Compose中就簡單多了

stickyHeader

Compose設(shè)計的時候考慮得很周到,他們提供了stickyHeader

作用就是添加一個粘性標題項,即使在它后面滾動時也會保持固定。標頭將保持固定,直到下一個標頭取而代之。

參數(shù)key - 表示唯一的密鑰鍵。

它不允許對列表出現(xiàn)使用相同的鍵。密鑰的類型應(yīng)該可以通過 Bundle 保存。如果傳遞了 null,則列表中的位置將代表鍵。當指定鍵時,滾動位置將基于該鍵保持,這意味著如果在當前可見項目之前添加刪除項目,則具有給定鍵的項目將保留為第一個可見項目。

參數(shù)content 傳入Composable控件就即可顯示

實體類

創(chuàng)建一個實體類標題和內(nèi)容

data class Post(
    val title:String,
    val contentData:List<String>
)

加載假數(shù)據(jù)

val list : MutableList<Post> = mutableListOf()
for (index in 1..10) {
    val contentData :MutableList<String> = mutableListOf()
    for (i in 1..30){
        contentData.add("內(nèi)容 $i")
    }
    list.add(Post("標題$index",contentData))
}

定義一個垂直滾動列表,僅構(gòu)成和布局當前可見的項目

LazyColumn {
    list.forEachIndexed { position, post ->
        stickyHeader {
            ListTitle(title = post.title)
        }

        items(post.contentData.size) { route ->
            StructureItem(post.contentData)
        }
        if (position <= list.size - 1) {
            Divider()
        }
        Spacer(modifier = Modifier.height(10.dp))
    }
}

吸頂標題

接著封裝一個吸頂標題,并傳出點擊事件

@Composable
fun ListTitle(
    onSubtitleClick: () -> Unit = {}
) {
        MediumTitle(
            title = title,
            modifier = Modifier.align(Alignment.CenterVertically).clickable {
                onSubtitleClick.invoke()
            }
}

效果圖

二級條目

接著寫二級條目

FlowRow可以將其子項置于水平流中的可組合項。如果水平空間太小而無法將所有子項放在一行中,則可能會使用多行。傳統(tǒng)的流式布局

用法很簡單,和row一樣

FlowRow {
    for (item in bean) {
        TextButton(
           ....
        }
    }
}

在content可組控件里面添加多個TextButton即可

fun StructureItem{
    Column{
        FlowRow() {
            for (item in bean) {
                TextButton
                {
                    Text()
                }

            }
        }

    }
}

效果圖

接著吸頂標題放在LazyColumn里面就完成了

LazyColumn() {
    list.forEachIndexed { position, post ->
        stickyHeader {
            ListTitle(title = post.title) {
                //點擊事件
            }
        }
        item {
            StructureItem(post.contentData)
            Spacer(modifier = Modifier.height(10.dp))
        }
    }
}

完整代碼

@OptIn(ExperimentalFoundationApi::class)
@Composable
fun StickyHeaderScreen() {
    val list: MutableList<Post> = mutableListOf()
    for (index in 1..10) {
        val contentData: MutableList<String> = mutableListOf()
        for (i in 1..12) {
            contentData.add("內(nèi)容 $i")
        }
        list.add(Post("標題$index", contentData))
    }
    LazyColumn(
        modifier = Modifier
            .fillMaxWidth()
            .fillMaxHeight(),
        contentPadding = PaddingValues(vertical = 10.dp)
    ) {
        list.forEachIndexed { position, post ->
            stickyHeader {
                ListTitle(title = post.title) {
                    //點擊事件
                }
            }
            item {
                StructureItem(post.contentData)
                Spacer(modifier = Modifier.height(10.dp))
            }
        }
    }
}

data class Post(
    val title: String,
    val contentData: List<String>
)

@Composable
fun ListTitle(
    modifier: Modifier = Modifier,
    title: String,
    isLoading: Boolean = false,
    onSubtitleClick: () -> Unit = {}
) {
    Row(
        modifier = modifier
            .placeholder(false)
            .fillMaxWidth()
            .height(ListTitleHeight)
            .background(color = Color.Gray)
    ) {
        Box(
            modifier = Modifier
                .padding(horizontal = 10.dp)
                .width(5.dp)
                .height(16.dp)
                .align(Alignment.CenterVertically)
                .background(color = Color.Black)
        )
        MediumTitle(
            title = title,
            color = Color.Black,
            modifier = Modifier.align(Alignment.CenterVertically).clickable {
                onSubtitleClick.invoke()
            },
            isLoading = isLoading
        )
        Spacer(modifier = Modifier.weight(1f))
    }

}


@Composable
fun StructureItem(
    bean: List<String>
) {
    Column(
        modifier = Modifier
            .fillMaxWidth()
            .padding(top = 10.dp)
    ) {

        FlowRow(
            modifier = Modifier.padding(horizontal = 6.dp)
        ) {


            for (item in bean) {
                Box(modifier = Modifier.padding(horizontal = 2.dp, vertical = 3.dp)) {
                    TextButton(
                        modifier = Modifier.padding(horizontal = 3.dp).height(34.dp),
                        shape = RoundedCornerShape(12.dp),
                        onClick = { },
                        colors = ButtonDefaults.textButtonColors(
                            backgroundColor = themeColor
                        )
                    )
                    {
                        Text(
                            item,
                            color = Color.White
                        )
                    }

                }
            }
        }

    }
}

效果圖

左邊的黑邊是我裁剪的問題,抱歉啦!

到此這篇關(guān)于Android Jetpack Compose實現(xiàn)列表吸頂效果的文章就介紹到這了,更多相關(guān)Jetpack Compose列表吸頂內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論