Android 制作自定义单选按钮

Android 制作自定义单选按钮,android,android-layout,material-design,android-radiobutton,android-chips,Android,Android Layout,Material Design,Android Radiobutton,Android Chips,我正在尝试制作一个自定义单选按钮,如下所示: 我尝试制作一个包含三个RadioButton的RadioGroup,RadioButton的背景是一个矩形,选中时RadioButton的背景是一个蓝色矩形,不选中时为白色,但它似乎不起作用 <RadioGroup android:id="@+id/Frequency" android:layout_width="370dp" android:layout_height="40dp" android:backg

我正在尝试制作一个自定义单选按钮,如下所示:

我尝试制作一个包含三个RadioButton的RadioGroup,RadioButton的背景是一个矩形,选中时RadioButton的背景是一个蓝色矩形,不选中时为白色,但它似乎不起作用

<RadioGroup
    android:id="@+id/Frequency"
    android:layout_width="370dp"
    android:layout_height="40dp"
    android:background="@drawable/radiorectangle"
    android:orientation="horizontal"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintHorizontal_bias="0.5"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toTopOf="parent"
    app:layout_constraintVertical_bias="0.614">

    <RadioButton
        android:id="@+id/Dailyrb"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:checked="true"
        android:text="Daily" />

    <RadioButton
        android:id="@+id/Weekly"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="Weekly" />

    <RadioButton
        android:id="@+id/Monthly"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="Monthly" />
</RadioGroup>

按钮

 <selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" >
    <shape android:shape="rectangle">
        <solid android:color="@color/clearBlue">
        </solid>
        <corners android:radius="16dp"></corners>
    </shape>
</item>
<item android:state_checked="false" >
    <shape android:shape="rectangle">
        <solid android:color="@color/white">
        </solid>
        <corners android:radius="16dp"></corners>
    </shape>
</item>


我建议您采用以下解决方案:

创建两种形状状态:

res/drawable/state\u checked.xml

<?xml version="1.0" encoding="UTF-8"?>
<shape android:shape="rectangle"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <solid android:color="@color/colorPrimary">
    </solid>
    <corners android:radius="16dp"></corners>
</shape>
<?xml version="1.0" encoding="UTF-8"?>
<shape android:shape="rectangle"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <solid android:color="#FFF">
    </solid>
    <corners android:radius="16dp"></corners>
</shape>
然后为文本和背景色定义选择器

res/drawable/
文件夹中创建
text\u selector.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="true" 
          android:color="#FFFFFF" /> <!-- text color when checked -->
    <item android:color="#000000" /> <!-- default text color-->
</selector>
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:state_checked="true"
        android:drawable="@drawable/state_checked" />

    <item android:drawable="@drawable/state_unchecked" />
</selector>
最后,添加背景选择器和文本选择器:

<RadioButton
    android:id="@+id/Dailyrb"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_weight="1"
    android:checked="true"
    android:textColor="@drawable/text_selector"
    android:background="@drawable/background_selector"
    android:text="Daily" />

<RadioButton
    android:id="@+id/Weekly"
    android:layout_width="0dp"
    android:background="@drawable/background_selector"
    android:textColor="@drawable/text_selector"
    android:layout_height="wrap_content"
    android:layout_weight="1"
    android:text="Weekly" />

<RadioButton
    android:id="@+id/Monthly"
    android:layout_width="0dp"
    android:textColor="@drawable/text_selector"
    android:background="@drawable/background_selector"
    android:layout_height="wrap_content"
    android:layout_weight="1"
    android:text="Monthly" />

见结果:


我建议您采用以下解决方案:

创建两种形状状态:

res/drawable/state\u checked.xml

<?xml version="1.0" encoding="UTF-8"?>
<shape android:shape="rectangle"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <solid android:color="@color/colorPrimary">
    </solid>
    <corners android:radius="16dp"></corners>
</shape>
<?xml version="1.0" encoding="UTF-8"?>
<shape android:shape="rectangle"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <solid android:color="#FFF">
    </solid>
    <corners android:radius="16dp"></corners>
</shape>
然后为文本和背景色定义选择器

res/drawable/
文件夹中创建
text\u selector.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="true" 
          android:color="#FFFFFF" /> <!-- text color when checked -->
    <item android:color="#000000" /> <!-- default text color-->
</selector>
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:state_checked="true"
        android:drawable="@drawable/state_checked" />

    <item android:drawable="@drawable/state_unchecked" />
</selector>
最后,添加背景选择器和文本选择器:

<RadioButton
    android:id="@+id/Dailyrb"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_weight="1"
    android:checked="true"
    android:textColor="@drawable/text_selector"
    android:background="@drawable/background_selector"
    android:text="Daily" />

<RadioButton
    android:id="@+id/Weekly"
    android:layout_width="0dp"
    android:background="@drawable/background_selector"
    android:textColor="@drawable/text_selector"
    android:layout_height="wrap_content"
    android:layout_weight="1"
    android:text="Weekly" />

<RadioButton
    android:id="@+id/Monthly"
    android:layout_width="0dp"
    android:textColor="@drawable/text_selector"
    android:background="@drawable/background_selector"
    android:layout_height="wrap_content"
    android:layout_weight="1"
    android:text="Monthly" />

见结果:

您可以使用中包含的默认值


您可以使用中包含的默认值



这不是一个完全的解决方案,只是一个简单的方法。我认为您可以使用
Tablayout
实现此行为。请参阅。它将像一个团队一样工作。试试看。这不是一个完全的解决方案,只是一个简单的方法。我认为您可以使用
Tablayout
实现此行为。请参阅。它将像一个团队一样工作。试试看。