动态布局中RadioGroup的RadioButton有时候不互斥的原因

最近在做一个答题类的模块,有单选、简答、调查问卷等,我是用动态布局的方式生成答题项的,在弄单选的时候遇到一个比较奇葩的问题,在代码中生成RadioGroup和RadioButton的时候,会发现不能互斥,变成多选。通过排查发现,只要每个RadioButton去掉setId的设置就正常了,不过原因还是不明确,继续尝试,发现RadioGroup我也设置了一个Id座位题目标识,调用的是RadioGroup.setId,并且发现,这里设置的ID和后面某个RadioButton设置的Id是一样的。。。终于找到问题所在,其实核心就一个,同一个布局里面Id是不能重复的,放在XML布局我们一目了然(当然IDE不让你通过编译),解决之。。。。


在 Kotlin RadioButtons(单选按钮)默认就是互斥的,也就是说,一次只能选择其的一个。当用户点击一个RadioButton时,其他已经被选RadioButton会自动取消状态。这是因为RadioButton通常在同一个RadioGroup使用,RadioGroup内部的RadioButton是通过`android:exclusive="true"`属性设置为互斥的。 当你创建 RadioGroup 时,可以这样做: ```kotlin val radioButtonGroup = RadioButton(this) radioButtonGroup.group = radioGroup // 将 RadioButton 添加到 RadioGroup val radioButton1 = RadioButton(radioButtonGroup.context) radioButton1.text = "Option 1" radioButton1.id = R.id.radioButton1 // 添加到 RadioGroup radioButtonGroup.addView(radioButton1) val radioButton2 = RadioButton(radioButtonGroup.context) radioButton2.text = "Option 2" radioButton2.id = R.id.radioButton2 // 添加到 RadioGroup radioButtonGroup.addView(radioButton2) ``` 然后在 XML 文件,你可以定义 RadioGroup 并设置 `android:exclusive="true"` 属性: ```xml <RadioGroup android:id="@+id/radioGroup" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" android:exclusive="true"> <!-- your radio buttons here --> </RadioGroup> ``` 如果你需要自定义互斥行为或者有特殊需求,还可以在代码监听 `onCheckedChangeListener` 来控制状态切换: ```kotlin radioButtonGroup.setOnCheckedChangeListener { _, checkedId -> when (checkedId) { R.id.radioButton1 -> radioButton2.isChecked = false R.id.radioButton2 -> radioButton1.isChecked = false else -> // 处理未选的情况 } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值