单选框(RadioButton)和复选框(CheckBox)的功能与用法

单选框(RaidoButton)复选框(CheckBox)状态开关按钮(ToggleButton)和开关(Switch)是用户界面中最普通的UI组件,他们都继承了Button类,因此都可直接使用Button支持的各种属性个方法。


RadioButton、CheckBox与普通按钮不同的是,他们多了一个可选择的功能,因此RadioButton、CheckBox都可额外指定一个android:checked属性,该属性用于指定RadioButton、CheckBox初始时是否被选中。


RadioButton与CheckBox的不同之处在于,一组RadioButton只能选中其中一个,因此RaidoButton通常要与RadioGroup一起使用,用于定义一组单选钮。


实例:利用单选钮、复选框获取用户信息。

界面布局文件如下。

xml version="1.0" encoding="utf-8"?>
xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:context="com.example.l2112.checkbuttontest.MainActivity"
    tools:showIn="@layout/activity_main">
    
            android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="性别" />
    
            android:id="@+id/rg"
        android:orientation="horizontal"
        android:layout_gravity="center_horizontal">
    
            android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/male"
        android:text="男"
        android:checked="true"/>
            android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/female"
        android:text="女"/>
    
    

    
                    android:layout_height="wrap_content"
            android:layout_width="wrap_content"
            android:text="喜欢的颜色:"/>
        
                    android:layout_gravity="center_horizontal"
            android:orientation="vertical"
            android:layout_height="wrap_content"
            android:layout_width="wrap_content">
            
                            android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="蓝色"/>
                            android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="红色"/>
                            android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="绿色"/>
        
    
            android:id="@+id/show"
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"/>


注意:如果在XML布局文件中默认勾选了某个单选按钮,则必须为改租单选钮的每个按钮指定android:id属性值;否则无法正常工作。


为了监听单选钮、复选框的勾选状态的改变,可以为他们添加事件监听器。

package com.example.l2112.checkbuttontest;

import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.RadioGroup;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity {
    RadioGroup rg;
    TextView show;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

        FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                        .setAction("Action", null).show();
            }
        });
        //获取界面上rg、show两个组件
        rg = (RadioGroup) findViewById(R.id.rg);
        show = (TextView) findViewById(R.id.show);
        //为RadioGroup组件的OnCheckedChange事件绑定事件监听器
        rg.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener()
        {
            @Override
                    public void onCheckedChanged(RadioGroup group,int checkedId)
            {
                String tip = checkedId == R.id.male?"您的性别是男人":"您的性别是女人";
                show.setText(tip);
            }
        });
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.menu_main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            return true;
        }

        return super.onOptionsItemSelected(item);
    }
}

运行程序后如下。

单选框(RadioButton)和复选框(CheckBox)的功能与用法_第1张图片



你可能感兴趣的:(android开发;)