`

自定义RatingBar/SeekBar,重载样式

阅读更多
Android系统自带的是星星,我们不能随心所欲的更换自己喜欢的图片,下面我就来讲讲如何制作自己的RatingBar样式。
    1、在res/data/style.xml文件中定义种样式:
<resources>
    <style name="myratingbar"    
               parent="@android:style/Widget.RatingBar.Small">
         <item 
              name="android:progressDrawable">
              @drawable/myratingbar
         </item>
         <item name="android:minHeight">36dip</item>
         <item name="android:maxHeight">36dip</item>
    <style>
</resources>

其中继承的父类可以选择RatingBar,RatingBar.Indicator,RatingBar.Small;
    大小可以自己定义。
    注意:RatingBar,RatingBar.Indicator,RatingBar.Small的不同点除了他们的显示大小不同以外,主要的还有Ratingbar中的IsIndicator属性是false,其他两种是true.该属性为false表示可以相应用的点击事件,通过这种方式可以和用户交互。
2、在res/drawable/myratingbar.xml文件指定不同图层的图片资源
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
	<item android:id="@+android:id/background" 
	android:drawable="@drawable/myratingbar_off" />
	<item android:id="@+android:id/secondaryProgress"
		android:drawable="@drawable/myratingbar_half" />
	<item android:id="@+android:id/progress" 
	android:drawable="@drawable/myratingbar_on" />
</layer-list> 


android评分条RatingBar自定义设置
http://fariytale.iteye.com/blog/1260673

RatingBar自定义设置
http://wang-peng1.iteye.com/blog/720956

SeekBar自定义
http://heji.iteye.com/blog/669266

Android下修改SeekBar样式
http://blog.csdn.net/vrix/archive/2010/08/03/5785676.aspx

垂直显示的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.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 = 22;
        		height = 160;
                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;
     	}
}


关于SeekBar无法拖到最大值的解决办法:
seekbar的android:layout_width设置为fill_parent。
假如seekbar的max值比较小的话,那无法拖到最后的最大值。
解决方法很简单,加padding:
android:paddingLeft="13dip"
android:paddingRight="13dip"
分享到:
评论
1 楼 gangbener 2012-02-21  
"Android系统自带的是星星,我们不能随心所欲的更换自己喜欢的图片",现在可以换图片了,在xml中加入"android:progressDrawable"就可以

相关推荐

    Android自定义Ratingbar星星实现评分

    本篇文章将详细探讨如何根据实际需求自定义RatingBar,实现星星之间的间距调整,以及分享一个自定义RatingBar的实例——MyRatring。 首先,我们要理解Android RatingBar的基本用法。RatingBar是基于ProgressBar的...

    android自定义RatingBar

    然而,系统默认的RatingBar样式可能无法满足所有设计需求,这时就需要进行自定义来达到特定的视觉效果。这篇博客(http://blog.csdn.net/xiangxi101/article/details/51455678)详细讲解了如何在Android中自定义一个...

    自定义ratingBar

    然而,系统默认的RatingBar样式可能无法满足所有设计需求,因此我们需要自定义RatingBar以达到特定的视觉效果。本篇将详细介绍如何在Android中自定义一个用星形来显示等级评定的RatingBar。 一、自定义RatingBar的...

    android中自定义ratingbar方法(含代码)

    但是,系统默认的 RatingBar 样式可能不够美观,于是我们需要自定义 RatingBar 的样式来满足我们的需求。在这篇文章中,我们将介绍如何自定义 RatingBar 的方法,并提供相应的代码示例。 自定义 RatingBar 样式 ...

    Android安卓自定义RatingBar控件(解决了多分辨率问题,以及被截取或者有阴影的问题)

    7. **样式资源**:创建自定义的样式资源,如`style.xml`中定义`&lt;style name="CustomRatingBar"&gt;`,包含`&lt;item name="android:progressDrawable"&gt;@drawable/custom_ratingbar_progress&lt;/item&gt;`和`...

    android 自定义RatingBar源码实例

    系统默认的RatingBar样式可能无法满足所有设计需求,因此开发者经常需要对其进行自定义以达到更美观的效果。本文将深入探讨如何通过源码实例来实现自定义RatingBar。 首先,RatingBar的基本用法是创建一个XML布局...

    安卓自定义RatingBar,支持整数小数递增递减

    8. **样式和主题**:根据设计需求,开发者可能需要为RatingBar提供多种样式。通过改变颜色、大小、间距等属性,可以定制出符合应用风格的RatingBar。 综上所述,自定义RatingBar是一个涉及Android基础组件、图形...

    自定义RatingBar,五星评论

    4. 自定义星星的样式 - 设计不同状态的星星图片,如全星图、空星图和半星图。 - 将这些图片设置到LevelListDrawable的各个级别中。 - 通过设置RatingBar的stepSize属性为0.5,使得它可以显示半星。 5. 动态改变...

    Android自定义RatingBar的背景图片

    默认情况下,RatingBar的样式和颜色可能无法满足所有设计需求,因此开发者常常需要对其进行自定义,以达到更个性化的视觉效果。本文将详细介绍如何自定义RatingBar的背景图片以及解决在Android 6.0(API级别23)设备...

    Android重写View的自定义Ratingbar

    由于项目中需要使用到ratingbar,可之前每次使用总有各种各样的限制 使用过的小伙伴可能会有所体会,这次需要设置ratingbar之间的间距,我试了很多种方法都无效 迫于无奈,只能自己写一个呗 现在分享出来给小伙伴们...

    自定义RatingBar项目代码

    然而,Android系统默认的RatingBar样式可能不能满足所有设计需求,因此开发者经常需要自定义RatingBar来达到特定的视觉效果。本文将详细介绍如何在Android项目中实现自定义RatingBar。 首先,我们需要了解RatingBar...

    自定义RatingBar

    // 加载自定义样式 if (attrs != null) { TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.CustomRatingBar); try { setMax(a.getInt(R.styleable.CustomRatingBar_max, 5)); setStepSize...

    android自定义RatingBar显示效果

    android自定义RatingBar显示效果

    自定义Ratingbar以及显示密码

    1. **样式定制**:可以通过修改默认的XML资源文件,如`res/drawable/ratingbar.xml`,来改变星星的形状、颜色、大小等。例如,可以创建不同状态的图片(未选中和已选中)作为星星的图标。 2. **数量设置**:通过`...

    自定义的RatingBar

    RatingBar继承自ProgressBar,它有三种显示样式:small、normal和large。通过设置`android:indeterminateDrawable`、`android:minHeight`和`android:maxHeight`等属性可以调整RatingBar的外观。系统默认的RatingBar...

    自定义RatingBar的显示(评分组件)

    自定义RatingBar可以让你更好地控制其外观和行为,以适应应用的独特设计需求。本篇文章将深入探讨如何自定义RatingBar的显示。 首先,RatingBar的基础用法是通过XML布局文件来配置。在`res/layout`目录下创建一个新...

Global site tag (gtag.js) - Google Analytics