开关控件(可随手指移动)的
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了开关控件(可随手指移动)的相关的知识,希望对你有一定的参考价值。
开关
1、继承View
2、测量宽高,等于背景图片的宽高
3、绘制自己,背景+滑动块
4、处理触摸事件,让滑动块随手指移动
1、继承View
public class ToggleButton extends View {
public ToggleButton(Context context, AttributeSet attrs) {
super(context, attrs);
}
}
2、测量宽高,等于背景图片的宽高
public class ToggleButton extends View {
private Bitmap backgroundBitmap;
private Bitmap slideBitmap;
private int slideLeftPos;// 滑动块距离左边的距离
private int slideLeftPosMax;
public ToggleButton(Context context, AttributeSet attrs) {
super(context, attrs);
// 初始化背景图片和滑动块图片
backgroundBitmap = BitmapFactory.decodeResource(getResources(), R.drawable.toogle_background);
slideBitmap = BitmapFactory.decodeResource(getResources(), R.drawable.toogle_slidebg);
slideLeftPosMax = backgroundBitmap.getWidth()-slideBitmap.getWidth();// 滑动块距离左边最大值
}
// 测量
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
// 设置自己的宽高,把背景图片的宽高作为自己的宽高
setMeasuredDimension(backgroundBitmap.getWidth(), backgroundBitmap.getHeight());
}
}
3、绘制自己,背景+滑动块
// 绘制
@Override
protected void onDraw(Canvas canvas) {
// 绘制背景图片
canvas.drawBitmap(backgroundBitmap, 0, 0, null);
// 绘制滑动块
canvas.drawBitmap(slideBitmap, slideLeftPos, 0, null);
}
4、处理触摸事件,让滑动块随手指移动
// 处理触摸事件
@Override
public boolean onTouchEvent(MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
downX = (int) event.getX();
break;
case MotionEvent.ACTION_MOVE:
int moveX = (int) event.getX();
// 计算手指移动的距离
int distanceX = moveX - downX;
// 更新滑动块距离左边的距离
slideLeftPos += distanceX;
// 限制滑动块距离左边的距离
if(slideLeftPos<0){
slideLeftPos = 0;
}else if(slideLeftPos>slideLeftPosMax){
slideLeftPos = slideLeftPosMax;
}
// 每次移动后,需要把当前move的位置赋值给down
downX = moveX;
// 重新绘制控件
invalidate();
break;
case MotionEvent.ACTION_UP:
// 计算滑动块中间点的位置,与背景图片中间点进行比较
// 滑动块中间点的位置<背景图片中间点 ,应该画到最左边,否则画到最右边
if(slideLeftPos + slideBitmap.getWidth()/2<backgroundBitmap.getWidth()/2){
slideLeftPos = 0;
}else{
slideLeftPos = slideLeftPosMax;
}
// 重新绘制控件
invalidate();
break;
default:
break;
}
return true;// 消费掉事件
}
以上是关于开关控件(可随手指移动)的的主要内容,如果未能解决你的问题,请参考以下文章