本文以一个简单的小例子,简述在Android开发中ToggleButton(开关按钮)和Switch(开关)的简单使用,仅供学习分享使用。

概述

ToggleButton是一个有两种状态(checked/unchecked)的按钮,经常用于开/关等场景中,默认文本显示(ON/OFF),Switch 是一个拥有两种状态的控件,具有滑动的效果。

ToggleButton

ToggleButton涉及知识点如下:

  1. android:textOff 设置未选中时显示的文本内容,默认为OFF。
  2. android:textOn 设置选中时显示的文本内容,默认为ON。
  3. android:disabledAlpha 控件禁用时的透明度,float类型,
  4. android:background 背景设置,可以用于设置一个图片或者资源文件
  5. setOnCheckedChangeListener 用于设置监听状态改变的事件
  6. OnCheckedChangeListener 状态监听事件,是一个接口,有一个函数需要实现
  7. onCheckedChanged(CompoundButton buttonView, boolean isChecked) 监听事件需要实现的函数

ToggleButton示例效果图如下:

ToggleButton源码

(xml)源码如下:

  <TextView
android:id="@+id/tv_toggle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@id/sp_info"
android:textSize="15dp"
android:layout_marginBottom="10dp"
android:text="@string/tv_toggle"/>
<ToggleButton
android:id="@+id/tb_info"
android:textOff=""
android:textOn=""
android:layout_marginBottom="10dp"
android:background="@drawable/toggle_selector"
android:layout_below="@id/tv_toggle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>

关于toggle_selector资源文件如下(资源文件中的on和off对应图片):

 <?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/on"></item>
<item android:state_checked="false" android:drawable="@drawable/off"></item>
</selector>

实现监听事件的源码如下:

 mToggleButton =(ToggleButton) this.findViewById(R.id.tb_info);
mToggleButton.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
String info="当前状态是:"+(isChecked?"打开":"关闭");
Toast.makeText(MainActivity.this,info,Toast.LENGTH_LONG).show();
}
});

Switch控件

Switch涉及知识点如下:

  1. android:textOff 设置未选中时显示的文本内容,默认为OFF。
  2. android:textOn 设置选中时显示的文本内容,默认为ON。
  3. android:thumb:滑块的图片
  4. android:showText:设置on/off的时候是否显示文字,boolean
  5. android:splitTrack:是否设置一个间隙,让滑块与底部图片分隔,boolean
  6. setOnCheckedChangeListener 用于设置监听状态改变的事件
  7. OnCheckedChangeListener 状态监听事件,是一个接口,有一个函数需要实现
  8. onCheckedChanged(CompoundButton buttonView, boolean isChecked) 监听事件需要实现的函数

Switch示例效果图如下:

Switch源码

xml源码如下(其中的toggle_selector和上面一样,设置选中和未选中时的图片):

 <Switch
android:id="@+id/sw_info"
android:textOff=""
android:textOn=""
android:background="@drawable/toggle_selector1"
android:track="@drawable/toggle_selector1"
android:layout_below="@id/tb_info"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>

监听事件源码如下:

 mSwitch =(Switch)this.findViewById(R.id.sw_info);
mSwitch.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
String info="当前状态是:"+(isChecked?"打开":"关闭");
Toast.makeText(MainActivity.this,info,Toast.LENGTH_LONG).show();
}
});

备注

ToggleButton和Switch是很常见的基础性控件,简单易用,场景广泛,本文旨在抛砖引玉,希望大家共同学习。

一起学Android之ToggleButton和Switch的更多相关文章

  1. Android的ToggleButton和Switch以及AnalogColok和DigitalColok的用法-android学习之旅(二十)

    ToggleButton 和Switch简介 ToggleButton 和Switch都是继承了Button,所以他们的属性设置和Button差不多. 分别支持的属性 ToggleButton 的属性 ...

  2. android开关控件Switch和ToggleButton

    序:今天项目中用到了开关按钮控件,查阅了一些资料特地写了这篇博客记录下. 1.Switch <Switch android:id="@+id/bt" android:layo ...

  3. Android零基础入门第21节:ToggleButton和Switch使用大全

    原文:Android零基础入门第21节:ToggleButton和Switch使用大全 上期学习了CheckBox和RadioButton,那么本期来学习Button的另外两个子控件ToggleBut ...

  4. Android基础控件ToggleButton和Switch开关按钮

    1.简介 ToggleButton和Switch都是开关按钮,只不过Switch要Android4.0之后才能使用! ToggleButton <!--checked 是否选择--> &l ...

  5. 菜鸟学Android编程——简单计算器《一》

    菜鸟瞎搞,高手莫进 本人菜鸟一枚,最近在学Android编程,网上看了一些视频教程,于是想着平时手机上的计算器应该很简单,自己何不尝试着做一个呢? 于是就冒冒失失的开撸了. 简单计算器嘛,功能当然很少 ...

  6. ToggleButton与Switch

    状态开关按钮togglebutton和开关switch 状态开关按钮togglebutton和开关switch是由button派生出来的,本质也是按钮,支持BUtton的各种属性,从功能上看,Togg ...

  7. 设置ToggleButton、Switch、CheckBox和RadioButton的显示效果

    ToggleButton.Switch.CheckBox和RadioButton都是继承自android.widget.CompoundButton,意思是可选择的,因此它们的用法都很类似.Compo ...

  8. 一步一步学android控件(之六) —— MultiAutoCompleteTextView

    今天学习的控件是MultiAutoCompleteTextView . 提到MultiAutoCompleteTextView 我们就自然而然地想到AutoCompleteTextView ,就想知道 ...

  9. android的toogleButton和switch的使用方法

    这两个是button开关.监听CheckedChangeListener toggle_layout.xml: <? xml version="1.0" encoding=& ...

随机推荐

  1. MySSL HTTPS 评级 B 升 A+

    背景 MySSL 提供了免费的网站 HTTPS 安全评级服务,然后我用我的网站 https://hellogithub.com,测试了一下.发现安全评级为 B,最高为 A+.下面是记录我的网站从 B ...

  2. Vue源码解析(二):数据驱动

    一.数据驱动: 数据驱动是vue.js最大的特点.在vue.js中,数据驱动就是当数据发生变化的时候,用户界面发生相应的变化,开发者不需要手动的去修改dom.数据驱动还有一部分是数据更新驱动视图变化. ...

  3. 如何设置Linux(Centos)系统定期任务(corntab详细用法)

    如何设置Linux(Centos)系统定期任务(crontab详细用法) 1.Crontab简介 Linux 系统则是由 cron (crond) 这个系统服务来控制的.Linux 系统上面原本就有非 ...

  4. CMake简介

    目录 一.CMake简介 二.CMake典型示例 源代码 demo.cpp cmake脚本 CMakeLists.txt 编译流程 三.CMake常用命令 常用命令介绍 设置编译目标类型 指定编译包含 ...

  5. Visual Studio高效实用的扩展工具、插件

    说明: 对一个有想法的程序员来说,善于使用一款高效的开发工具是很重要的,今天给大家介绍的是宇宙第一IDE vs用起来很不错的开发工具,假如大家觉得不错也可以尝试的用用,毕竟对于我们这些一天一大半的时间 ...

  6. python基础-函数(9)

    一.函数的介绍 如果在开发程序时,需要某块代码多次,但是为了提高编写的效率以及代码的重用,所以把具有独立功能的代码块组织为一个小模块,这就是函数 函数的语法格式: def 函数名(): 函数的功能代码 ...

  7. [区块链] 带你进入Bitcoin开发 - 环境搭建

    学习完区块链枯燥乏味的.高深的.必备的基础知识后,终于可以走上开发之路了!真是迫不及待啦!之后博客更新主要放在区块链的开发上,相信这才是大多数同学更加感兴趣的地方!学习过程从最经典的区块链鼻祖-比特币 ...

  8. WindowUtils【窗口工具类】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 判断当前界面是横屏还是竖屏: 获取当前界面方向. 效果图   代码分析 isLandscape(Context context): ...

  9. 将svg文件化成字体图标的步骤

     一 前提摘要     有一个活就是按照需求在现有的项目中新增几个项目和修改几个项目,是很简单的,但当中遇到了一个小问题,就是tabs中图标选中和被选中的颜色问题,如果是新开发的,目前掌握的有两种办法 ...

  10. 强化学习(三)用动态规划(DP)求解

    在强化学习(二)马尔科夫决策过程(MDP)中,我们讨论了用马尔科夫假设来简化强化学习模型的复杂度,这一篇我们在马尔科夫假设和贝尔曼方程的基础上讨论使用动态规划(Dynamic Programming, ...