RadioButton自定义样式及点击事件全解析

本文详细解析了如何在Android中实现RadioButton的文字置于下方、设置选中时的样式,以及在RadioGroup中创建并处理点击事件。通过调整drawable属性实现文字位置,创建select.xml设置选中样式,并通过代码初始化和监听RadioButton。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.设置文字在下边的RadioButton

这里写图片描述

<RadioButton
   android:id="@+id/rb_male"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_marginRight="50dp"
   android:text="男孩"
   android:button="@null"
   android:gravity="center"
   android:textColor="@color/black"
   android:drawableTop="@drawable/ic_launcher"
   android:checked="true" />

主要代码为 android:button="@null"android:drawableTop="@drawable/ic_launcher"
可以看到 drawableTop、drawableBottom、drawableLeft、drawableRight 可以用来随意设置位置来实现文字的位置。

2.设置RadioButton选中时的样式

在drawable中创建一个select.xml,加入以下代码即可。

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:drawable="@drawable/ic_select_sex_male_p" android:state_checked="true" />
    <item android:drawable="@drawable/ic_select_sex_male_n" android:state_checked="false" />

</selector>

使用方法

<RadioButton
    android:id="@+id/rb_male"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginRight="50dp"
    android:button="@null"
    android:checked="true"
    android:drawableTop="@drawable/select"
    android:gravity="center"
    android:text="男孩"
    android:textColor="@color/black" />

3.建立RadioGroup中的RadioButton

初始化控件

private void setUpView() {
   rg_sex = (RadioGroup) findViewById(R.id.rg_sex);
   rb_sex_male = (RadioButton) findViewById(R.id.rb_sex_male);
   rb_sex_female = (RadioButton) findViewById(R.id.rb_sex_female);
 }

获取对应RadioButton的点击事件(默认值可以设置)

private void setRadioGroupOnCheckedChangeListener() {
        rg_sex.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {

            @Override
            public void onCheckedChanged(RadioGroup group, int checkedId) {

                if (checkedId == rb_sex_male.getId()) {

                } else (checkedId == rb_sex_female.getId()) {

                }

            }
        });
    }

xml布局

              <RadioGroup
                    android:id="@+id/rg_sex"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_centerInParent="true"
                    android:gravity="center"
                    android:orientation="horizontal" >

                    <RadioButton
                        android:id="@+id/rb_sex_male"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_marginRight="50dp"
                        android:button="@null"
                        android:checked="true"
                        android:drawableTop="@drawable/a"
                        android:gravity="center"
                        android:text="男孩"
                        android:textColor="@color/black" />

                    <RadioButton
                        android:id="@+id/rb_sex_female"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_marginLeft="50dp"
                        android:button="@null"
                        android:drawableTop="@drawable/b"
                        android:text="女孩"
                        android:textColor="@color/black" />
                </RadioGroup>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值