android自定义渐变进度条

</pre>       项目中需要用到一个弧形渐变的进度条,通过android自带是不能实现的,我是没有找到实现的方法,有大神知道的可以指点,效果图是下面这样的<p></p><p><img src="" alt="" /><img src="" alt="" /></p><p>       这是通过继承VIew来绘制出来的,网上也有类似的,但是代码那是相当的累赘,而且创建了很多无用的对象</p><p>       我在这把自定义的View代码贴出来了,用到的话可以加以参考</p><p></p><pre code_snippet_id="1652650" snippet_file_name="blog_20160419_2_2646915" name="code" class="java">public class SpringProgressView extends View {

	/**
	 * 分段颜色
	 */

	private static final int[] SECTION_COLORS = {Color.RED, Color.parseColor("#ffa000"), Color.YELLOW};

	/**
	 * 进度条最大值
	 */
	private float maxCount;
	/**
	 * 进度条当前值
	 */
	private float currentCount;
	/**
	 * 画笔
	 */
	private Paint mPaint;
	private int mWidth, mHeight;

	private RectF rectBg = new RectF();
	private RectF rectProgressBg = new RectF();
	private LinearGradient shader;

	public SpringProgressView(Context context, AttributeSet attrs, int defStyleAttr) {
		super(context, attrs, defStyleAttr);
		initView(context);
	}

	public SpringProgressView(Context context, AttributeSet attrs) {
		super(context, attrs);
		initView(context);
	}

	public SpringProgressView(Context context) {
		super(context);
		initView(context);
	}

	private void initView(Context context) {
		mPaint = new Paint();
	}

	@Override
	protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
		super.onLayout(changed, left, top, right, bottom);
		mHeight = bottom - top;
		mWidth = right - left;
		rectBg.set(0, 0,mWidth, mHeight);
	}

	@Override
	protected void onDraw(Canvas canvas) {
		super.onDraw(canvas);
		float section = currentCount / maxCount;
		if (shader == null) {
			shader = new LinearGradient(0, 0, mWidth, mHeight, SECTION_COLORS, null, Shader.TileMode.CLAMP);
		}
		mPaint.setShader(shader);
		mPaint.setAntiAlias(true);
		mPaint.setStyle(Paint.Style.STROKE);

		//绘制进度条外侧边框
		int round = mHeight*2/3;
		canvas.drawRoundRect(rectBg, round, round, mPaint);

		//绘制进度条
		mPaint.setStyle(Paint.Style.FILL);
		int pl=(int)(mWidth*(1-section));
		rectProgressBg.set(pl, 0, mWidth, mHeight);
		canvas.drawRoundRect(rectProgressBg, round, round, mPaint);
	}

	/*
     * 设置最大的进度值
     */
	public void setMaxCount(float maxCount) {
		this.maxCount = maxCount;
	}

	/**
	 * 设置当前的进度值
	 */
	public void setCurrentCount(float currentCount) {
		this.currentCount = currentCount > maxCount ? maxCount : currentCount;
		invalidate();
	}

	public float getMaxCount() {
		return maxCount;
	}

	public float getCurrentCount() {
		return currentCount;
	}

}

以上就是自定义的view部分,直接在布局文件中引用就可以了,在Activity中设置该进度条的最大值和和当前进度值,就可以完美实现了

我也把代码地址粘下来,可以下载http://download.csdn.net/detail/u013122144/9495668

时间: 2024-07-28 23:09:40

android自定义渐变进度条的相关文章

android自定义圆形进度条,实现动态画圆效果

自定义圆形进度条效果图如下:应用场景如动态显示分数等. view的自定义属性如下attr.xml <?xml version="1.0" encoding="UTF-8"?> <resources> <declare-styleable name="ArcProgressbar">         <!-- 圆环起始角度-->         <attr name="startAng

Android -- 自定义带进度条的按钮

1. 实现了一个带进度条的按钮,完成后显示提示信息,并设置按钮为不可再次被点击 2. 所需要的图片               3.  代码 MainActivity package com.example.buttondemo; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.view.View;

Android自定义圆形进度条

首先看一下效果: 自定义的View: import com.example.circlepregress.R; import android.content.Context; import android.content.res.TypedArray; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.RectF

android自定义渐变圆环进度条

先看下效果: 分析:比较常见于扫描结果.进度条等场景 利用canvas.drawArc(RectF oval, float startAngle, float sweepAngle, boolean useCenter, Paint paint)绘制圆弧 Paint的一些属性定义粗细.颜色.样式等 LinearGradient实现颜色的线型渐变 同样的道理,可以画出长条进度条,扇图饼图等,感兴趣可以试下.. package com.liujing.progressviewdemo; /*** *

【Android进度条】三种方式实现自定义圆形进度条ProgressBar

一.通过动画实现 定义res/anim/loading.xml如下: [html] view plaincopyprint? <?xml version="1.0" encoding="UTF-8"?> <animation-list android:oneshot="false" xmlns:android="http://schemas.android.com/apk/res/android"> &

Android HorizontalProgressBar 自定义横向进度条

Android HorizontalProgressBar 横线进度条 效果图如下: 自定义需要继承  ProgressBar: 直接在布局文件中引用: ' 设置进度: ' 样式文件:   下载地址:https://download.csdn.net/download/littyzhon/10420429 参考地址:https://www.jianshu.com/p/777e67db5b53 原文地址:https://www.cnblogs.com/code-wind/p/9050738.htm

自定义控件之圆形颜色渐变进度条--SweepGradient

前几天在群里面有人找圆形可颜色渐变进度条,其中主要的知识点是SweepGradient: mSweepGradient = new SweepGradient(240, 360, new int[] { Color.CYAN, Color.DKGRAY, Color.GRAY, Color.LTGRAY, Color.MAGENTA, Color.GREEN, Color.TRANSPARENT, Color.BLUE }, null); 如上:第三个参数为渐变颜色内容,前两个是坐标信息,240

Android自定义控件:进度条的四种实现方式

前三种实现方式代码出自: http://stormzhang.com/openandroid/2013/11/15/android-custom-loading/ (源码在最后) 最近一直在学习自定义控件,搜了许多大牛们Blog里分享的小教程,也上GitHub找了一些类似的控件进行学习.发现读起来都不太好懂,就想写这么一篇东西作为学习笔记吧. 一.控件介绍: 进度条在App中非常常见,例如下载进度.加载图片.打开文章.打开网页等等--都需要这么一个效果让用户知道我们的App正在读取,以构造良好的

自定义环形进度条

自定义环形进度条 效果图: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 package com.qiao.circleprogress_forexample; import android.app.Activity; impo