<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginTop="20dp"
>
<Button
android:id="@+id/main_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_centerVertical="true"
android:layout_marginLeft="15dp"
android:paddingLeft="25dp"
android:paddingTop="3dp"
android:paddingRight="25dp"
android:paddingBottom="3dp"
android:text="切换状态"
android:textSize="15sp" />
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:layout_marginRight="20dp"
>
<LinearLayout
android:id="@+id/main_linearlayout"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
>
<com.android.switctview.SwitchView
android:id="@+id/main_myslipswitch"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</LinearLayout>
</LinearLayout>
</RelativeLayout>
"

</LinearLayout>




package com.android.switctview;

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;

public class SwitchView extends View implements OnTouchListener{
//开关开启时的背景,关闭时的背景,滑动按钮
private Bitmap switch_on_Bkg, switch_off_Bkg, slip_Btn;
private Rect on_Rect, off_Rect;

//是否正在滑动
private boolean isSlipping = false;
//当前开关状态,true为开启,false为关闭
private boolean isSwitchOn = false;

//手指按下时的水平坐标X,当前的水平坐标X
private float previousX, currentX;

//开关监听器
private OnSwitchListener onSwitchListener;
//是否设置了开关监听器
private boolean isSwitchListenerOn = false;


public SwitchView(Context context) {
super(context);
init();
}


public SwitchView(Context context, AttributeSet attrs) {
super(context, attrs);
init();
}


private void init() {
setOnTouchListener(this);
}

protected void setImageResource(int switchOnBkg, int switchOffBkg, int slipBtn) {
switch_on_Bkg = BitmapFactory.decodeResource(getResources(), switchOnBkg);
switch_off_Bkg = BitmapFactory.decodeResource(getResources(), switchOffBkg);
slip_Btn = BitmapFactory.decodeResource(getResources(), slipBtn);

//右半边Rect,即滑动按钮在右半边时表示开关开启
on_Rect = new Rect(switch_off_Bkg.getWidth() - slip_Btn.getWidth(), 0, switch_off_Bkg.getWidth(), slip_Btn.getHeight());
//左半边Rect,即滑动按钮在左半边时表示开关关闭
off_Rect = new Rect(0, 0, slip_Btn.getWidth(), slip_Btn.getHeight());
}


protected void setSwitchState(boolean switchState) {
isSwitchOn = switchState;
}


protected boolean getSwitchState() {
return isSwitchOn;
}


protected void updateSwitchState(boolean switchState) {
isSwitchOn = switchState;
invalidate();
}


@Override
protected void onDraw(Canvas canvas) {
// TODO Auto-generated method stub
super.onDraw(canvas);

Matrix matrix = new Matrix();
Paint paint = new Paint();
//滑动按钮的左边坐标
float left_SlipBtn;

//手指滑动到左半边的时候表示开关为关闭状态,滑动到右半边的时候表示开关为开启状态
if(currentX < (switch_on_Bkg.getWidth() / 2)) {
canvas.drawBitmap(switch_off_Bkg, matrix, paint);
} else {
canvas.drawBitmap(switch_on_Bkg, matrix, paint);
}

//判断当前是否正在滑动
if(isSlipping) {
if(currentX > switch_on_Bkg.getWidth()) {
left_SlipBtn = switch_on_Bkg.getWidth() - slip_Btn.getWidth();
} else {
left_SlipBtn = currentX - slip_Btn.getWidth() / 2;
}
} else {
//根据当前的开关状态设置滑动按钮的位置
if(isSwitchOn) {
left_SlipBtn = on_Rect.left;
} else {
left_SlipBtn = off_Rect.left;
}
}

//对滑动按钮的位置进行异常判断
if(left_SlipBtn < 0) {
left_SlipBtn = 0;
} else if(left_SlipBtn > switch_on_Bkg.getWidth() - slip_Btn.getWidth()) {
left_SlipBtn = switch_on_Bkg.getWidth() - slip_Btn.getWidth();
}

canvas.drawBitmap(slip_Btn, left_SlipBtn, 0, paint);
}


@Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
switch(event.getAction()) {
//滑动
case MotionEvent.ACTION_MOVE:
currentX = event.getX();
break;

//按下
case MotionEvent.ACTION_DOWN:
if(event.getX() > switch_on_Bkg.getWidth() || event.getY() > switch_on_Bkg.getHeight()) {
return false;
}

isSlipping = true;
previousX = event.getX();
currentX = previousX;
break;

//松开
case MotionEvent.ACTION_UP:
isSlipping = false;
//松开前开关的状态
boolean previousSwitchState = isSwitchOn;

if(event.getX() >= (switch_on_Bkg.getWidth() / 2)) {
isSwitchOn = true;
} else {
isSwitchOn = false;
}

//如果设置了监听器,则调用此方法
if(isSwitchListenerOn && (previousSwitchState != isSwitchOn)) {
onSwitchListener.onSwitched(isSwitchOn);
}
break;

default:
break;
}

//重新绘制控件
invalidate();
return true;
}


public void setOnSwitchListener(OnSwitchListener listener) {
onSwitchListener = listener;
isSwitchListenerOn = true;
}


public interface OnSwitchListener {
abstract void onSwitched(boolean isSwitchOn);
}
}



package com.android.switctview;

import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.LinearLayout;
import android.widget.LinearLayout.LayoutParams;
import android.widget.Toast;

import com.android.switctview.SwitchView.OnSwitchListener;

public class SwitchActivity extends Activity {


private Bitmap switch_on_Bkg;
private LinearLayout linearlayout_LL;
private SwitchView slipswitch_MSL;
private Button button_Btn;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
switch_on_Bkg = BitmapFactory.decodeResource(getResources(), R.drawable.bkg_switch);
LayoutParams layoutParams = new LayoutParams(switch_on_Bkg.getWidth(), switch_on_Bkg.getHeight());

linearlayout_LL = (LinearLayout)findViewById(R.id.main_linearlayout);
linearlayout_LL.setLayoutParams(layoutParams);

slipswitch_MSL = (SwitchView)findViewById(R.id.main_myslipswitch);
slipswitch_MSL.setSwitchState(true);
slipswitch_MSL.setImageResource(R.drawable.bkg_switch, R.drawable.bkg_switch, R.drawable.btn_slip);
slipswitch_MSL.setOnSwitchListener(new OnSwitchListener() {

@Override
public void onSwitched(boolean isSwitchOn) {
// TODO Auto-generated method stub
if(isSwitchOn) {
Toast.makeText(SwitchActivity.this, "开关已经开启", 300).show();
} else {
Toast.makeText(SwitchActivity.this, "开关已经关闭", 300).show();
}
}
});

button_Btn = (Button)findViewById(R.id.main_button);
button_Btn.setOnClickListener(new OnClickListener() {

@Override
public void onClick(View v) {
// TODO Auto-generated method stub
slipswitch_MSL.updateSwitchState(!slipswitch_MSL.getSwitchState());

if(slipswitch_MSL.getSwitchState()) {
Toast.makeText(SwitchActivity.this, "开关已经开启", 300).show();
} else {
Toast.makeText(SwitchActivity.this, "开关已经关闭", 300).show();
}
}
});

}
}

更多相关文章

  1. Android(安卓)CheckBox实现SwitchButton
  2. android状态栏下载
  3. Android(安卓)蓝牙服务端实现
  4. android简单一级购物车
  5. android 第三方分享
  6. 过期API_AlertDialog
  7. android 管理wifi
  8. android activity Understand the Lifecycle Callback
  9. Chapter 1 Introducing Android(安卓)Studio

随机推荐

  1. Android Animation--->TweemAnimation运
  2. Android 开发记录 环境平台的搭建
  3. android 2.3源码 下载与编译 以前我让我
  4. Android Studio 如何切换sdk
  5. [置顶] Android手机点击查看手机电量Demo
  6. Android(安卓)Studio 手机运行时中文乱码
  7. android仿苹果分段按钮
  8. android EditText插入字符串到光标所在位
  9. android 以编程的方式使用SQLite数据库
  10. Android 一个下载任务分为多个线程下载