`
zhujianjia
  • 浏览: 485843 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

竖着的SeekBar(VerticalSeekBar)

阅读更多

竖着的Seekbar:

 

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Rect;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.view.KeyEvent;
import android.view.MotionEvent;
import android.view.View;
import android.widget.AbsSeekBar;


public class VerticalSeekBar extends AbsSeekBar {
    private Drawable mThumb;
    private int height;
    private int width;
    public interface OnSeekBarChangeListener {
        void onProgressChanged(VerticalSeekBar VerticalSeekBar, int progress, boolean fromUser);
        void onStartTrackingTouch(VerticalSeekBar VerticalSeekBar);
        void onStopTrackingTouch(VerticalSeekBar VerticalSeekBar);
    }

    private OnSeekBarChangeListener mOnSeekBarChangeListener;
    
    public VerticalSeekBar(Context context) {
        this(context, null);
    }
    
    public VerticalSeekBar(Context context, AttributeSet attrs) {
        this(context, attrs, android.R.attr.seekBarStyle);
    }

    public VerticalSeekBar(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
    }

	public void setOnSeekBarChangeListener(OnSeekBarChangeListener l) {
        mOnSeekBarChangeListener = l;
    }
    
    void onStartTrackingTouch() {
        if (mOnSeekBarChangeListener != null) {
            mOnSeekBarChangeListener.onStartTrackingTouch(this);
        }
    }
    
    void onStopTrackingTouch() {
        if (mOnSeekBarChangeListener != null) {
            mOnSeekBarChangeListener.onStopTrackingTouch(this);
        }
    }
    
    
    void onProgressRefresh(float scale, boolean fromUser) {
        Drawable thumb = mThumb;
        if (thumb != null) {
            setThumbPos(getHeight(), thumb, scale, Integer.MIN_VALUE);
            invalidate();
        }
        if (mOnSeekBarChangeListener != null) {
        	mOnSeekBarChangeListener.onProgressChanged(this, getProgress(), fromUser);
        }
    }

    private void setThumbPos(int w, Drawable thumb, float scale, int gap) {
        int available = w+getPaddingLeft()-getPaddingRight();
        int thumbWidth = thumb.getIntrinsicWidth();
        int thumbHeight = thumb.getIntrinsicHeight();
        available -= thumbWidth;
        // The extra space for the thumb to move on the track
        available += getThumbOffset() * 2;
        int thumbPos = (int) (scale * available);
        int topBound, bottomBound;
        if (gap == Integer.MIN_VALUE) {
            Rect oldBounds = thumb.getBounds();
            topBound = oldBounds.top;
            bottomBound = oldBounds.bottom;
        } else {
            topBound = gap;
            bottomBound = gap + thumbHeight;
        }
        thumb.setBounds(thumbPos, topBound, thumbPos + thumbWidth, bottomBound);
    }
    protected void onDraw(Canvas c)
    {
            c.rotate(-90);
            c.translate(-height,0);
            super.onDraw(c);
    }
    //可以改变进度条的高和宽
    protected synchronized void onMeasure(int widthMeasureSpec, int heightMeasureSpec)
    {
    	width = 28;
  		height = View.MeasureSpec.getSize(heightMeasureSpec);
		//width = View.MeasureSpec.getSize(widthMeasureSpec);
        this.setMeasuredDimension(width, height);
    }
	@Override
	public void setThumb(Drawable thumb)
	{
        mThumb = thumb;
		super.setThumb(thumb);
	}
    protected void onSizeChanged(int w, int h, int oldw, int oldh)
    {
            super.onSizeChanged(h, w, oldw, oldh);
    }   
    public boolean onTouchEvent(MotionEvent event) {
        if (!isEnabled()) {
            return false;
        }        
        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN:
                setPressed(true);
                onStartTrackingTouch();
                trackTouchEvent(event);
                break;
                
            case MotionEvent.ACTION_MOVE:
                trackTouchEvent(event);
                attemptClaimDrag();
                break;
                
            case MotionEvent.ACTION_UP:
                trackTouchEvent(event);
                onStopTrackingTouch();
                setPressed(false);
                break;
                
            case MotionEvent.ACTION_CANCEL:
                onStopTrackingTouch();
                setPressed(false);
                break;
        }
        return true;
    }
    private void trackTouchEvent(MotionEvent event) {
        final int Height = getHeight();
        final int available = Height - getPaddingBottom() - getPaddingTop();
        int Y = (int)event.getY();
        float scale;
        float progress = 0;
        if (Y > Height - getPaddingBottom()) {
            scale = 0.0f;
        } else if (Y  < getPaddingTop()) {
            scale = 1.0f;
        } else {
            scale = (float)(Height - getPaddingBottom()-Y) / (float)available;
        }
        
        final int max = getMax();
        progress = scale * max;
        
        setProgress((int) progress);
    }
    
    private void attemptClaimDrag() {
        if (getParent() != null) {
        	getParent().requestDisallowInterceptTouchEvent(true);
        }
    }
    public boolean dispatchKeyEvent(KeyEvent event) {
    	if(event.getAction()==KeyEvent.ACTION_DOWN)
    	{
    		KeyEvent newEvent = null;
    		switch(event.getKeyCode())
    		{
    			case KeyEvent.KEYCODE_DPAD_UP:
    				newEvent = new KeyEvent(KeyEvent.ACTION_DOWN,KeyEvent.KEYCODE_DPAD_RIGHT);
    				break;
    			case KeyEvent.KEYCODE_DPAD_DOWN:
    				newEvent = new KeyEvent(KeyEvent.ACTION_DOWN,KeyEvent.KEYCODE_DPAD_LEFT);
    				break;
    			case KeyEvent.KEYCODE_DPAD_LEFT:
    				newEvent = new KeyEvent(KeyEvent.ACTION_DOWN,KeyEvent.KEYCODE_DPAD_DOWN);
    				break;
    			case KeyEvent.KEYCODE_DPAD_RIGHT:
    				newEvent = new KeyEvent(KeyEvent.ACTION_DOWN,KeyEvent.KEYCODE_DPAD_UP);
    				break;
    			default:
    				newEvent = new KeyEvent(KeyEvent.ACTION_DOWN,event.getKeyCode());
					break;
    		}
    		return newEvent.dispatch(this);
    	}
    	return false;
    }
}
 
分享到:
评论

相关推荐

    android实例竖着的seekbar

    在布局XML文件中,我们可以像使用普通SeekBar那样使用这个自定义的VerticalSeekBar,只需将类名指定为我们刚才创建的`VerticalSeekBar`。 ```xml 垂直SeekBar android:id="@+id/vertical_seekbar" android:layout...

    [Android实例] Android 竖着的SeekBar.rar

    我们将深入讲解这个"Android竖着的SeekBar"实例,了解其背后的实现原理和代码结构。 首先,要创建竖直的SeekBar,我们需要自定义一个View类,并继承自SeekBar。在Android SDK中,SeekBar的滑块运动是沿着X轴进行的...

    Android-VerticalSeekBar竖直滑动条用起来比较方便

    在XML布局文件中,你可以像添加其他任何控件一样添加VerticalSeekBar,只需将`android.widget.SeekBar`替换为`android.widget.VerticalSeekBar`。下面是一个基本示例: ```xml &lt;android.widget.VerticalSeekBar ...

    Android实例Android 竖着的SeekBar.rar

    在本实例中,我们将探讨如何创建一个竖直方向的SeekBar,即“VerticalSeekbar”。 首先,我们要明白,Android SDK并未提供内置的垂直SeekBar。因此,我们需要自定义一个View来实现这一功能。在提供的...

    Android实例之[Android实例] Android 竖着的SeekBar

    1. 创建自定义View类:我们可以创建一个新的Java类,比如VerticalSeekBar,继承自SeekBar。在构造函数中,我们可以初始化一些基本属性,如滑动的最小值和最大值。 ```java public class VerticalSeekBar extends ...

    Android 竖着的SeekBar.zip

    标题“Android 竖着的SeekBar”指向的就是这样一个自定义实现,即在一个Android Studio项目中创建一个垂直滚动的SeekBar。 在Android Studio中开发自定义View通常涉及以下步骤: 1. 创建一个新的Java类,继承自...

    [Android实例] Android 竖着的SeekBar

    然而,标准的SeekBar是水平排列的,而在这个实例中,我们将探讨如何实现一个竖直方向上的SeekBar,即“竖着的SeekBar”。 ### 一、垂直SeekBar的原理 Android SDK并没有提供内置的垂直SeekBar,但通过自定义View或...

    [Android实例] Android 竖着的SeekBar.zip

    本实例就是关于如何在Android中实现一个竖向的SeekBar。 首先,我们需要理解Android的SeekBar是如何工作的。它继承自ProgressBar,提供了一个可交互的进度条。默认情况下,用户可以通过水平滑动SeekBar来改变其表示...

    [Android实例] Android 竖着的SeekBar_Android.rar

    【Android实例】Android竖向SeekBar详解 在Android开发中,SeekBar是一个常见的UI组件,通常用于显示进度条并允许用户通过拖动来改变进度。默认情况下,SeekBar是水平展示的,但在某些应用场景下,如垂直布局或者...

    安卓Android源码——[实例] 竖着的SeekBar.zip

    本实例将探讨如何在Android中创建一个竖向的SeekBar。 一、源码解析 在提供的"Android实例"中,我们可以通过查看源码来理解竖向SeekBar的实现方式。通常,这会涉及到自定义View的创建,覆盖onDraw()方法以绘制垂直...

Global site tag (gtag.js) - Google Analytics