自定义竖直方向的seekbar(一)

众所周知,安卓系统自带的seekbar是水平方向的,但是有时候设计师设计出来的东西是竖直方向的,这个也不怪设计师,毕竟隔行如隔山,我们可以继承系统默认的seekbar自定义一个竖直方向的,原理是在ondraw的时候对控件进行旋转:

import android.content.Context;
import android.graphics.Canvas;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.widget.SeekBar;

public class VerticalSeekBar extends SeekBar {  
  
    public VerticalSeekBar(Context context) {  
        super(context);  
    }  
  
    public VerticalSeekBar(Context context, AttributeSet attrs, int defStyle) {  
        super(context, attrs, defStyle);  
    }  
  
    public VerticalSeekBar(Context context, AttributeSet attrs) {  
        super(context, attrs);  
    }  
//将高和宽的参数进行对调
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {  
        super.onSizeChanged(h, w, oldh, oldw);  
    }  
  
    @Override  
    protected synchronized void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {  
        super.onMeasure(heightMeasureSpec, widthMeasureSpec);  
        setMeasuredDimension(getMeasuredHeight(), getMeasuredWidth());  
    }  
  
// 
    protected void onDraw(Canvas c) {  
        c.rotate(-90);  
        c.translate(-getHeight(), 0);  
        super.onDraw(c);  
  
        
    }  
// 
    @Override  
    public synchronized void setProgress(int progress) {  
        super.setProgress(progress);  
        onSizeChanged(getWidth(), getHeight(), 0, 0);  
    }  
  
    @Override  
    public boolean onTouchEvent(MotionEvent event) {  
        if (!isEnabled()) {  
            return false;  
        }  
  
        switch (event.getAction()) {  
            case MotionEvent.ACTION_DOWN:    
            case MotionEvent.ACTION_MOVE:  
            case MotionEvent.ACTION_UP:  
                setProgress(getMax() - (int) (getMax() * event.getY() / getHeight()));  
                onSizeChanged(getWidth(), getHeight(), 0, 0);  
                break;                
  
            case MotionEvent.ACTION_CANCEL:  
                break;  
        }  
        return true;  
    }
}
然后再XML中对自定义控件进行引用,即可。但是有时候会出现thumb无法居中对齐的现象,所以,下一篇文章中,将会介绍seekbar的style自定义和thumb无法居中的解决办法。

你可能感兴趣的:(自定义竖直方向的seekbar(一))