当前位置:首页 > 引流 > 正文内容

设置radiobutton选中(radiobutton设置单选教程)

admin3年前 (2022-10-11)引流791

在Jetpack Compose中用于制作单选按钮的可组合函数名为RadioButton。单选按钮是用户可以选择的小圆形按钮。一次只能选择一个选项。下面向您介绍如何使用RadioButton,如何实现多个RadioButton中一次只能选择一个选项的效果。

RadioButton(selected = false, onClick = { /*TODO*/ })

我们用非常简洁的代码就创建了一个RadioButton,如下图:  

RadioButton

此时的RadioButton没有任何的效果,也不能点击。

接下来,我们要为RadioButton添加一个点击状态并设置RadioButton的不同状态的样式。

val isSelected = remember {mutableStateOf(false)}
RadioButton(
    colors = RadioButtonDefaults.colors(
        selectedColor = selectedColor1,
        unselectedColor = unselectedColor1,
        disabledColor = disabledColor1
    ),
    enabled = true,
    selected = isSelected.value,
    onClick = { isSelected.value = !isSelected.value})

在上面的代码中,我们新建了一个isSelected变量来保存RadioButton的点击状态,使用colors设置RadioButton的样式,这里使用RadioButtonDefaults实例,并使用所需的背景色作为参数对其调用colors方法。

selectedColor:选中并启用时用于单选按钮的颜色

unselectedColor:未选择并启用时用于单选按钮的颜色。

disabledColor:禁用时用于单选按钮的颜色。

使用selected在“选定”和“未选定”之间切换按钮的当前状态。使用enabled控制单选按钮的启用状态。onClick单击RadioButton时要调用的回调,在回调中更改状态的值。如下图:

   

在Jetpack Compose中,RadioButton没有设置文字的属性,要想使其显示文字,就要使用组合项来实现。

val isSelected = remember {mutableStateOf(false)}
Row(
    modifier = Modifier.clickable {
        isSelected.value = !isSelected.value
    }) {
    RadioButton(
        colors = RadioButtonDefaults.colors(
            selectedColor = selectedColor1,
            unselectedColor = unselectedColor1,
            disabledColor = disabledColor1
        ),
        enabled = true,
        selected = isSelected.value,
        onClick = { isSelected.value = !isSelected.value })
    Spacer(modifier = Modifier.width(2.dp))
    Text(text = text)
}

在上面的代码中,我们在Row(线性水平)布局中添加了RadioButtonText两个组合项,实现RadioButton显示文字的效果,使用Spacer添加间隔,在RowModifier.clickable中,当点击整个布局也可以更改RadioButton的状态,如下图:  

显示文字效果

我们知道在Android开发中向RadioGroup中添加多个RadioButton,可以实现多个选项中只有一个RadioButton选中的效果,但在Jetpack Compose中没有这样的实现,我们需要自己自定义一个组合。

@Composable
fun MyRadioButtonList(context: Context){
    val fruits = listOf("苹果", "枇杷", "樱桃", "草莓")
    val selectedButton = remember { mutableStateOf(fruits.first()) }

    Row() {
        fruits.forEach {
            val isSelected = it == selectedButton.value
            Row(
                verticalAlignment = Alignment.CenterVertically,
                modifier = Modifier.clickable(onClick = {
                    selectedButton.value = it
                    Toast.makeText(context, "您点击了${it}", Toast.LENGTH_SHORT).show()
                })
            ) {
                RadioButton(
                    colors = RadioButtonDefaults.colors(
                        selectedColor = selectedColor1,
                        unselectedColor = unselectedColor1,
                        disabledColor = disabledColor1
                    ),
                    selected = isSelected,
                    onClick = {
                        selectedButton.value = it
                        Toast.makeText(context, "您点击了${it}", Toast.LENGTH_SHORT).show()
                    })
                Spacer(modifier = Modifier.width(2.dp))
                Text(text = it)
            }
        }
    }
}

在上面的代码中,首先,我们新建了一个fruits集合,我们用集合中的选项表示每个单选按钮的索引。接下来,创建一个selectedButton状态,以记住当前选择的按钮。默认情况下,选择第一个按钮。使用for循环,在循环的每次迭代中向列添加一个RadioButton。每次循环的使用我们判断selectedButton的值是否是当前的RadioButton,然后将isSelected的赋给RadioButton,每次用户点击按钮时,您都会更改在状态中选择的按钮。这将触发重新编译,您的UI将更新!如下图:

   

默认情况下会选择第一个RadioButton。选择另一个RadioButton时,可以看到在RadioButton之间切换状态。这样就实现了我们的单选效果。

扫描二维码推送至手机访问。

版权声明:本文中部分文字、图片、音频、视频来源于互联网及公开渠道,仅供学习参考,版权归原创者所有! 如侵犯到您的权益,请及时通知我们!我们将在第一时间内删除。

本文链接:http://73ya.com/yinliu/2169.html

分享给朋友:

“设置radiobutton选中(radiobutton设置单选教程)” 的相关文章

如何在抖音做推广 抖音广告、视频推广怎么做

抖音这个流量圣地,很多人都想要做一些推广。但其中是有着许多需要学习的东西的,那么应该怎么做呢?今天我们就一起了看看关于如何在抖音做推广,抖音广告、视频推广怎么做的相关内容。 如何在抖音做推广 一、怎么拍视频 视频是视频推广的核心基础,现在视频拍摄很容易,只要拿出手机就能拍,但要拍出好...

抖音视频剪辑教程 抖音视频剪辑怎么做

说到抖音,大家都会在上面刷刷短视频吧。但我们可以自己尝试制作,剪辑上应该怎么做呢?今天我们就一起来看看关于抖音视频剪辑教程,抖音视频剪辑怎么做的相关内容。 抖音视频剪辑教程 其实现在大部分的短视频都是通过手机剪辑制作出来的...

新手也能用的视频剪辑软件有哪些,有什么特点

随着抖音短视频做的越来越好,想做的人越来越多,很多人都想在短视频行业分一杯羹。可是不知道要从何入手。那么接下来就跟着小编一起来看看新手也能用的视频剪辑软件有哪些?轻松带你上路。 新手也能用的视频剪辑软件有哪些 1、快剪辑:快剪辑是一款包含PC版、IOS版、安卓版的免费剪辑软件,软件占用...

快手一分购好礼是什么,带动快手电商发展

经历过线上流量的红利时期,电商的行情开始有了减退的趋势。也有了一些显著的市场变化。那些曾经屡试不爽的增长玩法,在如今内卷严重的存量竞争中已经变得不再管用。越来越多的人喜欢在空闲的时间刷小视频什么的。家庭主妇买菜买日用品的时候总喜欢通过社群拼团买到便宜好货……这令社交电商行业不断被开拓,“...

快手直播怎么下载安装,快手直播安装要注意哪些

短视频直播是2022年短视频下半场的重头戏,抖音、快手了,作为短视频领域两大巨头,其直播板块更是内容创作者们争夺的主要阵地。很多主播都开始转换阵地,快手直播越来越热门。更多精彩等你来看。 在往期文章中,我们分享过抖音直播开通的方式和条件,今天这篇文章为大家分享快手直播下载安装及开通流程...

短视频未来会是什么样,短视频发展历程

短视频未来会是什么样?有哪些发展?很多小伙伴都没有发现短视频现在发展越来越快,已经逐渐步入生活的每一个角落里,接下来大家就跟着我一起来看看吧。 一、影视:从影院到手机 1895年法国卢米埃尔兄弟拍摄了第一部无声电影《工厂大门》,片长仅一分钟。这哥俩拍了大量这样的一分钟短片到处放映,这就...