原文地址:http://blog.youkuaiyun.com/lilu_leo/article/details/7661459
就是很像开关的那种控件,它只有两个状态:on和off:在IOS中,有个UISwitch控件,其效果图,如下:

在android4.0里面,添加了一个和这个类似的控件:Switch,很形象,开关。效果图如下:

其类关系图如下:
| java.lang.Object | |||||
| ↳ | android.view.View | ||||
| ↳ | android.widget.TextView | ||||
| ↳ | android.widget.Button | ||||
| ↳ | android.widget.CompoundButton | ||||
| ↳ | android.widget.Switch | ||||
类的概述:
Switch是一个可以在两种状态切换的开关控件。用户可以拖动"thumb"来回选择,也可以像选择复选框一样点击切换Switch的状态。
主要方法:
| Public Methods | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|
| int |
getCompoundPaddingRight()
Returns the right padding of the view, plus space for the right Drawable if any.
| ||||||||||
| CharSequence |
getTextOff()
Returns the text displayed when the button is not in the checked state.
| ||||||||||
| CharSequence |
getTextOn()
Returns the text displayed when the button is in the checked state.
| ||||||||||
| void |
jumpDrawablesToCurrentState()
Call
Drawable.jumpToCurrentState() on all Drawable objects associated with this view.
| ||||||||||
| void |
onMeasure(int widthMeasureSpec, int heightMeasureSpec)
Measure the view and its content to determine the measured width and the measured height. | ||||||||||
| void |
onPopulateAccessibilityEvent(
AccessibilityEvent event)
Called from
dispatchPopulateAccessibilityEvent(AccessibilityEvent) giving a chance to this View to populate the accessibility event with its text content.
| ||||||||||
| boolean |
onTouchEvent(
MotionEvent ev)
Implement this method to handle touch screen motion events.
| ||||||||||
| void |
setChecked(boolean checked)
Changes the checked state of this button. | ||||||||||
| void |
setSwitchTextAppearance(
Context context, int resid)
Sets the switch text color, size, style, hint color, and highlight color from the specified TextAppearance resource.
| ||||||||||
| void |
setSwitchTypeface(
Typeface tf, int style)
Sets the typeface and style in which the text should be displayed on the switch, and turns on the fake bold and italic bits in the Paint if the Typeface that you provided does not have all the bits in the style that you specified.
| ||||||||||
| void |
setSwitchTypeface(
Typeface tf)
Sets the typeface in which the text should be displayed on the switch.
| ||||||||||
| void |
setTextOff(
CharSequence textOff)
Sets the text displayed when the button is not in the checked state.
| ||||||||||
| void |
setTextOn(
CharSequence textOn)
Sets the text displayed when the button is in the checked state.
| ||||||||||
getCompoundPaddingRight():没弄清楚什么意思。
在TextView中的源码:
- <span style="font-family:System;">public int getCompoundDrawablePadding() {
- final Drawables dr = mDrawables;
- return dr != null ? dr.mDrawablePadding : 0;
- }</span>
jumpDrawableToCurrentState():在与Switch相关的Drawable操作时调用 Drawable.jumpToCurrentState()这个方法。
getTextOff()、getTextOn()、 setTextOff()、setTextOn()这四个方法比较简单,就是设定和获取非选中和选中状态下的文本值。
onMeasure():测量控件宽高,供绘图时使用。
onTouchEvent(MotionEvent ev)实现这一方法传递触摸屏运动事件。
setChecked()设置Switch的状态(选中,非选中)
setSwitchTextAppearance()设置字体大小
setSwitchTextTypefaces设置字体格式
看看google官方在/frameworks/base/core/res/res/values/styles.xml的一个定义:
- <span style="font-family:System;"><span style="color:#000000;"><style name="Widget.Holo.CompoundButton.Switch">
- <item name="android:track">@android:drawable/switch_track_holo_dark</item>
- <item name="android:thumb">@android:drawable/switch_inner_holo_dark</item>
- <item name="android:switchTextAppearance">@android:style/TextAppearance.Holo.Widget.Switch</item>
- <item name="android:textOn">@android:string/capital_on</item>
- <item name="android:textOff">@android:string/capital_off</item>
- <item name="android:thumbTextPadding">12dip</item>
- <item name="android:switchMinWidth">96dip</item>
- <item name="android:switchPadding">16dip</item>
- </style></span></span>
可以在main.xml中这样定义:
- <span style="font-family:System;"><span style="color:#000000;"><Switch
- android:id="@+id/demo_switch"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_below="@+id/textView"
- android:textOn="开"
- android:textOff="关"
- /></span></span>
当Switch状态切换时:
- <span style="font-family:System;"><span style="color:#000000;">mSwitch.setOnCheckedChangeListener(new OnCheckedChangeListener() {
- @Override
- public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
- if(isChecked) {
- //选中时 do some thing
- statusText.setText("开");
- } else {
- //非选中时 do some thing
- statusText.setText("关");
- }
- }
- });</span></span>
基本上先简单的讲到这。

本文详细介绍了 Android 4.0 中新增的 Switch 控件。Switch 控件是一种可以在两种状态之间切换的开关,用户可以通过拖动滑块或者点击来改变状态。文章提供了 Switch 控件的主要方法介绍,并展示了如何在 XML 布局文件中定义 Switch 控件及其监听器。
1756

被折叠的 条评论
为什么被折叠?



