android studio创建android项目(6)——CheckBox复选框和toast的混合使用

1、项目需求

  1. 本项目是一个安卓项目,启动页面有多个复选框和一个TextView
  2. 复选框分别显示为北京、上海、广州;TextView的文字为:已经勾选的城市;
  3. 点击每个复选框时,toast提示复选框的内容和选中状态(true和false)
  4. 点击文字时,toast提示选中的城市有哪些

2、项目分析

  1. checkbox的勾选监听
    (1)循环取出checkbox,对每个checkbox设置勾选监听器
  2. TextView的点击监听
    (1)TextView需要设置点击监听器,监听器的作用是发一个toast
    (2)遍历复选框列表,判断复选框的选中状态,如果选中,就将文本添加到结果字符串中
    (3)显示toast
    (4)清除toast内容,还原到初始状态

3、布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/activity_main"
    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"
    android:orientation="vertical"
    tools:context="com.example.gui.checkbox1.MainActivity">
    <LinearLayout
        android:id="@+id/checklist"
        android:orientation="horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <CheckBox
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="北京"/>
        <CheckBox
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="上海"/>
        <CheckBox
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="广州"/>

    </LinearLayout>
    <TextView
        android:id="@+id/textview"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="已经勾选的城市"/>

</LinearLayout>

4、Activity

package com.example.gui.checkbox1;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.CheckBox;
import android.widget.CompoundButton;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {

    //声明checkbox所在的布局
    LinearLayout checklist;
    //checkbox个数
    int count;
    //保存选中的checkbox
    StringBuffer stringBuffer=new StringBuffer();

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

        /*1、监听每个checkbox*/
        checklist=(LinearLayout)findViewById(R.id.checklist);
        count=checklist.getChildCount();
        for(int i=0;i<count;i++){
            CheckBox box=(CheckBox)checklist.getChildAt(i);
            box.setOnCheckedChangeListener(new CheckBox.OnCheckedChangeListener(){
                @Override
                public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                    Toast.makeText(getApplicationContext(),buttonView.getText().toString()+isChecked,Toast.LENGTH_SHORT).show();
                }
            });
        }
        /*2、监听textview*/

        TextView textView=(TextView)findViewById(R.id.textview);
        textView.setOnClickListener(new TextView.OnClickListener(){
            @Override
            public void onClick(View v) {
                stringBuffer.append("已经勾选的城市有:");
                for(int i=0;i<count;i++){
                    CheckBox box=(CheckBox)checklist.getChildAt(i);
                    if(box.isChecked()){
                        stringBuffer.append(box.getText().toString());
                    }
                }
                Toast.makeText(getApplicationContext(),stringBuffer,Toast.LENGTH_SHORT).show();
                //清除内容,还原到初始状态
                stringBuffer=new StringBuffer();
            }
        });
    }
}

5、运行结果

apk下载链接:https://pan.baidu.com/s/1Ze5qDFiS97k4OOqF7v_nsQ
提取码:l93q

运行结果:
1、启动页:
在这里插入图片描述
2、选中北京
在这里插入图片描述
3、取消选中北京
在这里插入图片描述
4、只选中上海、广州,点击提交按钮,toast提示如下:
在这里插入图片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章