Android ToggleButton:状态切换的Button

转载 2016年08月30日 10:04:04

Android ToggleButton:状态切换的Button



Android ToggleButton:状态切换的Button

Android ToggleButton和Android Button类似,但是ToggleButton提供了一种选择机制,可以表达Button处于何种状态,比如常见的WiFi打开或者关闭状态等等这种类似与非门的状态机。
标准的Android ToggleButton样式简单,如果要实现自定义的、表达力丰富的ToggleButton,其中一个方式就是写selector.xml文件作为ToggleButton的background,现在写一个例子。
布局文件activity_main.xml:博客

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="zhangphil.demo.MainActivity">

    <ToggleButton
        android:id="@+id/toggleButton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:checked="true"
        android:textOff="关闭"
        android:textOn="打开"
        android:background="@drawable/selector"/>
</RelativeLayout>

activity_main.xml需要的、位于drawable目录下的selector.xml文件:博客

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@android:color/darker_gray" android:state_checked="false" />
    <item android:drawable="@android:color/holo_green_light" android:state_checked="true" />
</selector>

上层Java代码:

package zhangphil.demo;

import android.app.Activity;
import android.os.Bundle;
import android.widget.CompoundButton;
import android.widget.Toast;
import android.widget.ToggleButton;

public class MainActivity extends Activity {

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

        ToggleButton mToggleButton = (ToggleButton) findViewById(R.id.toggleButton);
        mToggleButton.setOnCheckedChangeListener(mOnCheckedChangeListener);
    }

    private ToggleButton.OnCheckedChangeListener mOnCheckedChangeListener = new ToggleButton.OnCheckedChangeListener() {

        @Override
        public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
            String s="";

            if(isChecked)
                s="打开";
            else
                s="关闭";

            Toast.makeText(getApplication(),s,Toast.LENGTH_SHORT).show();
        }
    };
}

代码运行结果如图:博客

Android ToggleButton:状态切换的Button

附录文章:博客

1,《Android Segmented RadioButton》链接地址:http://blog.csdn.net/zhangphil/article/details/51441677

2,《Android选项切换条SHSegmentControl》链接地址:http://blog.csdn.net/zhangphil/article/details/49720805

原文地址:http://blog.csdn.net/zhangphil/article/details/51720565

相关文章推荐

安卓三状态切换按钮TriStateToggleButton

源码分享 2016-11-24 12:11 安卓三状态切换按钮源码下载 TriState Toggle Button示例源码下载 一个完全可定制和超简单的三态切换按钮(如果你喜欢切换按...

UI--Android中的状态切换按钮自定义

Android中关于控制开关和页面/状态切换的使用场景还是比较多的。源生做的支持也有比如RadioGroup 和Tabhost等。这里准备通过自定义View来模仿学习下IOS两种常见UI样式: Swi...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

android的RadioButton切换不同的fragment

MainActivity.java package com.fragmentwechattest; import android.app.Activity; import android.app....

android使用radioButton 切换fragment 解决fragment叠影

public class MainActivity extends BaseActivity { @BindView(R.id.fragment) FrameLayout fragme...
  • ke_csdn
  • ke_csdn
  • 2016年10月19日 16:00
  • 1072

SwitchButton 开关按钮 的多种实现方式 (附源码DEMO)

刚开始接触开关样式的按钮是在IOS系统上面,它的切换以及滑动十分帅气,深入人心。 所谓的开关按钮,就是只有2个状态:on和off,下图就是系统IOS 7上开关按钮效果。 起初我在android上我只...

Android 实现点击两个按钮,原地切换界面

最近在项目中遇到这样一个问题,大致是在页面中有两个按钮,负责切换两个页面,只是在原地切换。类似账单流水,显示充值,消费。老规矩 上图,由于没有添加Select选择器,所以按钮没有点击效果。在运用中添加...
  • tsaopin
  • tsaopin
  • 2015年08月04日 22:56
  • 6075

Android_首页_按钮切换效果_选中、未选中

一、对于首页界面底部有多个按钮,如按钮(1,2,3),默认点击1,按钮1图片是选中状态,当点击2时,按钮2是选中图片,然而其它的是未选中状态, 二、具体操作: 1、画界面 在activity_...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

android Button 切换背景,实现动态按钮和按钮颜色渐变

android Button 切换背景,实现动态按钮和按钮颜色渐变 一、添加android 背景筛选器selector实现按钮背景改变     1、右键单击项目->new->Others->A...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Android ToggleButton:状态切换的Button
举报原因:
原因补充:

(最多只允许输入30个字)