Android开发笔记(六)——RadioButton

RadioButton通常用来实现选择,比如说性别等

先新建一个进行演示的activity RadioButtonActivity,此时 AndroidMainfest.xml 中会自动添加如下声明:

<activity android:name=".RadioButtonActivity"></activity>

如果没有添加则要自己手动添加,否则会跳转失败。

之后在 activity_main.xml 中添加一个Button用来进行RadioButton控件的展示:

<Button
    android:id="@+id/btn_radiobutton"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:text="RadioButton"
    android:textAllCaps="false"
    />

接下来在 MainActivity.java 中声明这个控件:

private Button mBtnRadioButton;

之后要在 MainActivity.java 中的 onCreate 函数中使用 findViewById 找到该button,接着设置一个点击事件,使其点击之后跳转到新的界面:

mBtnRadioButton=findViewById(R.id.btn_radiobutton);
mBtnRadioButton.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        //跳转到RadioButton的演示界面
        Intent intent=new Intent(MainActivity.this,RadioButtonActivity.class);
        startActivity(intent);
    }
});

由于每次都要重复写 setOnClickListener 函数中的点击事件,这里写一个 OnClick 类来实现 View.OnClickListener 接口的功能,再写一个方法 setListener() 来设置监听器,给每个控件设置点击事件, MainActivity.java 中的整体代码如下:

package com.example.myapplication;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {

    private Button mBtnTextView; //声明Button组件
    private Button mBtnButton;
    private Button mBtnEditText;
    private Button mBtnRadioButton;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mBtnTextView=findViewById(R.id.btn_textview);
        mBtnButton=findViewById(R.id.btn_button);
        mBtnEditText=findViewById(R.id.btn_edittext);
        mBtnRadioButton=findViewById(R.id.btn_radiobutton);
        setListener();
    }

    private void setListener(){
        OnClick onClick=new OnClick();
        mBtnTextView.setOnClickListener(onClick);
        mBtnButton.setOnClickListener(onClick);
        mBtnEditText.setOnClickListener(onClick);
        mBtnRadioButton.setOnClickListener(onClick);
    }

    private class OnClick implements View.OnClickListener{

        @Override
        public void onClick(View v) {
            Intent intent = null;
            switch (v.getId()){
                case R.id.btn_textview:
                    //跳转到TextView演示界面
                    intent=new Intent(MainActivity.this,TextViewActivity.class);
                    break;
                case R.id.btn_button:
                    //跳转到Button演示界面
                    intent=new Intent(MainActivity.this,ButtonActivity.class);
                    break;
                case R.id.btn_edittext:
                    //跳转到EditText演示界面
                    intent=new Intent(MainActivity.this,EditTextActivity.class);
                    break;
                case R.id.btn_radiobutton:
                    //跳转到RadinButton演示界面
                    intent=new Intent(MainActivity.this,RadioButtonActivity.class);
                    break;
            }
            startActivity(intent);
        }
    }
}

常用属性

<RadioGroup
    android:id="@+id/rg_1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
     >
    <RadioButton
        android:id="@+id/rb_1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="男"
        android:checked="true"
        android:textSize="18sp"
        />
    <RadioButton
        android:id="@+id/rb_2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="女"
        android:textSize="18sp"
        />
   </RadioGroup>

其中 android:checked="true" 是默认选中的属性,如果添加该选项必须要给 RadioButton 设置id!!

效果:

自定义样式

当想要自定义样式的时候,可以通过如下代码实现:

    <RadioGroup
        android:id="@+id/rg_2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:layout_below="@+id/rg_1"
        android:layout_marginTop="50dp"
        >
        <RadioButton
            android:id="@+id/rb_3"
            android:layout_width="100dp"
            android:layout_height="50dp"
            android:gravity="center"
            android:text="男"
            android:button="@null"
            android:checked="true"
            android:textSize="18sp"
            android:background="@drawable/radiobutton_check"
            />
        <RadioButton
            android:id="@+id/rb_4"
            android:layout_width="100dp"
            android:layout_height="50dp"
            android:gravity="center"
            android:text="女"
            android:button="@null"
            android:textSize="18sp"
            android:layout_marginLeft="10dp"
            android:background="@drawable/radiobutton_check"
            />
    </RadioGroup>

其中 android:button="@null" 是把前面的选项符号去掉,这里在 drawable 里面新建了一个 radiobutton_check.xml ,具体方法:右键 drawable ——> new ——> Drawable Resource File ,Root element设置为selector。
radiobutton_check.xml 中的代码如下:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="true">
        <shape>
            <solid android:color="#BECEBE"/>
            <corners android:radius="20dp"/>
        </shape>
    </item>

    <item android:state_checked="false">
        <shape>
            <stroke android:width="1dp"
                android:color="#BECEBE"/>
            <corners android:radius="20dp"/>
        </shape>
    </item>
</selector>

意思是没有选择的时候是描线效果,选中之后变成实心颜色,并且整体框架有弧度。

效果如下:

监听事件

这里在第一组选择框中进行测试,可以监听当前的选择。
RadioButtonActivity.java 中进行声明:

private RadioGroup mRg1;

接着在 onCreate 函数中使用 findViewById 找到该组件,然后设置监听事件:

mRg1=findViewById(R.id.rg_1);
mRg1.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
    @Override
    public void onCheckedChanged(RadioGroup group, int checkedId) {
                RadioButton radioButton=group.findViewById(checkedId);
    Toast.makeText(RadioButtonActivity.this,radioButton.getText(),Toast.LENGTH_SHORT).show();
    }
});

效果如下:

原文地址:https://www.cnblogs.com/yangdd/p/13289098.html