最近在公司,项目不是很忙了,偶尔看见一个兄台在CSDN求助,帮忙要一个自定义的渐变色进度条,我当时看了一下进度条,感觉挺漂亮的,就尝试的去自定义view实现了一个,废话不说,先上图吧!
   

这个自定义的view,完全脱离了android自带的ProgressView,并且没使用一张图片,这样就能更好的降低程序代码上的耦合性!

下面我贴出代码  ,大概讲解一下实现思路吧!

package com.spring.progressview;import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.LinearGradient;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.graphics.RectF;
import android.graphics.Shader;
import android.util.AttributeSet;
import android.view.View;/**** 自定义进度条* @author spring sky* Email:vipa1888@163.com* 创建时间:2014-1-6下午3:28:51*/
public class SpringProgressView extends View {/**分段颜色*/private static final int[] SECTION_COLORS = {Color.GREEN,Color.YELLOW,Color.RED};/**进度条最大值*/private float maxCount;/**进度条当前值*/private float currentCount;/**画笔*/private Paint mPaint;private int mWidth,mHeight;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) {}@Overrideprotected void onDraw(Canvas canvas) {super.onDraw(canvas);mPaint = new Paint();mPaint.setAntiAlias(true);int round = mHeight/2;System.out.println("max="+maxCount + "  current="+currentCount);mPaint.setColor(Color.rgb(71, 76, 80));RectF rectBg = new RectF(0, 0, mWidth, mHeight);canvas.drawRoundRect(rectBg, round, round, mPaint);mPaint.setColor(Color.BLACK);RectF rectBlackBg = new RectF(2, 2, mWidth-2, mHeight-2);canvas.drawRoundRect(rectBlackBg, round, round, mPaint);float section = currentCount/maxCount;RectF rectProgressBg = new RectF(3, 3, (mWidth-3)*section, mHeight-3);if(section <= 1.0f/3.0f){if(section != 0.0f){mPaint.setColor(SECTION_COLORS[0]);}else{mPaint.setColor(Color.TRANSPARENT);}}else{int count = (section <= 1.0f/3.0f*2 ) ? 2 : 3;int[] colors = new int[count];System.arraycopy(SECTION_COLORS, 0, colors, 0, count);float[] positions = new float[count];if(count == 2){positions[0] = 0.0f;positions[1] = 1.0f-positions[0];}else{positions[0] = 0.0f;positions[1] = (maxCount/3)/currentCount;positions[2] = 1.0f-positions[0]*2;}positions[positions.length-1] = 1.0f;LinearGradient shader = new LinearGradient(3, 3, (mWidth-3)*section, mHeight-3, colors,null, Shader.TileMode.MIRROR);mPaint.setShader(shader);}canvas.drawRoundRect(rectProgressBg, round, round, mPaint);}private int dipToPx(int dip) {float scale = getContext().getResources().getDisplayMetrics().density;return (int) (dip * scale + 0.5f * (dip >= 0 ? 1 : -1));}/**** 设置最大的进度值* @param maxCount*/public void setMaxCount(float maxCount) {this.maxCount = maxCount;}/**** 设置当前的进度值* @param currentCount*/public void setCurrentCount(float currentCount) {this.currentCount = currentCount > maxCount ? maxCount : currentCount;invalidate();}public float getMaxCount() {return maxCount;}public float getCurrentCount() {return currentCount;}@Overrideprotected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {int widthSpecMode = MeasureSpec.getMode(widthMeasureSpec);int widthSpecSize = MeasureSpec.getSize(widthMeasureSpec);int heightSpecMode = MeasureSpec.getMode(heightMeasureSpec);int heightSpecSize = MeasureSpec.getSize(heightMeasureSpec);if (widthSpecMode == MeasureSpec.EXACTLY || widthSpecMode == MeasureSpec.AT_MOST) {mWidth = widthSpecSize;} else {mWidth = 0;}if (heightSpecMode == MeasureSpec.AT_MOST || heightSpecMode == MeasureSpec.UNSPECIFIED) {mHeight = dipToPx(15);} else {mHeight = heightSpecSize;}setMeasuredDimension(mWidth, mHeight);}}

以上代码就是该控件的全部核心代码了
具体思路:
1.进度条,其实就是一个最大值和最小值的比例值,这个比例就是 当前值/最大值;
2.自定义的圆角问题,只要还是用到了Canvar的画板的drawRoundRect ;
3.渐变色:LinearGradient对象渲染,具体渲染的比例要自己计算,目前我的程序提供3中颜色渲染,具体规则是:
(1)当进度条占最大值的三分之一以下,则提供一种颜色
   (2)当最大值超过三分之一话,就区分是否超过三分之二,如果超过则用三种,否则用两种颜色,因为三种颜色各占总进度条的三分之一,这是一个初中数据的问题,自己慢慢画图吧!
4.怎么把进度条放在一个有圆角背景的上面,这个就是绘制两个圆角长方形:第一个作为背景,第二个作为进度条的实体,具体第二个进度的实体占多长,就是当前 currentCount/maxCount*自定义View的长度   ;

其他的,没啥技术难点了,做这种自定义控件,最重要的是,自定要根据人家的效果图,看懂实现思路,具体代码简历在思路上的,否则只会纸上谈兵!如果看不懂,就要多画图,具体的一步步计算,天长地久,也就能“练”出来了!

下面提供一个demo下载地址:SpringProgressDemo

转载于:https://www.cnblogs.com/springskyhome/p/3689911.html

android自定义进度条渐变色View,不使用任何图片资源相关推荐

  1. android自定义进度条_Android中的自定义进度栏

    android自定义进度条 Custom progress bar in android application gives it a personal touch. In this tutorial ...

  2. android自定义圆角进度条,Android自定义进度条的圆角横向进度条实例详解

    1.本文将向你介绍自定义进度条的写法,比较简单,但还是有些知识点是需要注意的: invalidate()方法 RectF方法的应用 onMeasure方法的应用 2.原理 画3层圆角矩形,底层为黑色, ...

  3. android 自定义 进度条 旋转,Android_Android ProgressBar进度条使用详解,ProgressBar进度条,分为旋转进 - phpStudy...

    Android ProgressBar进度条使用详解 ProgressBar进度条,分为旋转进度条和水平进度条,进度条的样式根据需要自定义,之前一直不明白进度条如何在实际项目中使用,网上演示进度条的案 ...

  4. android 自定义进度条 水量,Android自定义带水滴的进度条样式(带渐变色效果)...

    一.直接看效果 二.直接上代码 1.自定义控件部分 package com.susan.project.myapplication; import android.app.Activity; impo ...

  5. android自定义进度条百分比跟着走,Android自定义View实现水平带数字百分比进度条...

    这个进度条可以反映真实进度,并且完成百分比的文字时随着进度增加而移动的,所在位置也恰好是真实完成的百分比位置,效果如下: 思路如下:第一部分是左侧的蓝色直线,代表已经完成的进度:第二部分是右侧灰色的直 ...

  6. android 自定义progressbar demo,Android 自定义进度条ColorfulProgressbar,原理简单、效果还行...

    效果图: demo效果演示 演示Demo 特性 与原生Progress相比,感觉更漂亮一点,可以显示进度值,背景凹凸感明显,进度条效果更加立体. 原理说明 额,挺简单的.不过感觉我的做法有点复杂了,我 ...

  7. android 自定义进度条矩形框,Android 自定义方形进度条

    效果图如上,自定义方形的进度条,第一个是100%,第二个是70% 其实很简单的,就Path类 public class SquareProgressBar extends View { private ...

  8. android自定义进度条样式,Android 自定义进度条

    效果 国际惯例,效果图奉上 在这里插入图片描述 目录 在这里插入图片描述 前言 写在前面,由于之前其实已经写了部分自定义View的方法,所以本来应该按照之前的系列,来进行下载暂停动画进度条,但是我把之 ...

  9. Android自定义进度条

    Android原生控件只有横向进度条一种,而且没法变换样式,比如原生rom的样子 很丑是吧,当伟大的产品设计要求更换前背景,甚至纵向,甚至圆弧状的,咋办,比如 ok,我们开始吧:   一)变换前背景 ...

最新文章

  1. 鸟哥的Linux私房菜(服务器)- 第十四章、账号控管: NIS 服务器
  2. CentOS7默认的防火墙不是iptables,而是firewalle.
  3. Qt Qwdget 汽车仪表知识点拆解2 图像放大
  4. 控制x86汇编指令eip的方法
  5. linux 网络编程 ------------TCP多进程并发服务器
  6. 利润百倍的暴利行业?
  7. python制图一元迭代函数_Python中 生成器、迭代器、闭包、装饰器、元类实例分析...
  8. 大学生JAVA程序员周记,java程序员实习周记.docx
  9. 一波三折,终于找到src漏洞挖掘的方法了【建议收藏】
  10. Java词法分析器的设计与实现
  11. 先验 超验_经验、先验、超验
  12. 排序—时间复杂度为O(n2)的三种排序算法
  13. Ubuntu 20.04LTS 搜狗输入法不显示图标
  14. Python之列表和元组
  15. unpack php,php unpack函数怎么用
  16. [问题已处理]-mac安装cobra失败
  17. Python读写zip压缩文件
  18. teamlab什么意思_普通人如何能更有意义地参观美术馆?
  19. Gogole C++ 编程风格(二)
  20. Android Studio Chipmunk 同时打开多个项目的正确方法

热门文章

  1. Redis性能监控指标汇总
  2. 一文读懂Java 11的ZGC为何如此高效
  3. 中国SaaS死或生之二:ERP两大邪术,尽出歪门邪路
  4. Service Mesh 实践指南:从单体应用到 Service Mesh 的曲折历程
  5. Java Streams,第 2 部分: 使用流执行聚合
  6. Android --- 数据库存储的是正确的时间格式(2021-06-17 21:47:23)但是在获取的时候变成了(2021-06-17T13:47:23.000+00:00)
  7. log4j2配置文件log4j2.xml详解
  8. python读取mtcars数据集并实现以下操作_Python可视化43 | plotnine≈R语言ggplot2,43plotnineR...
  9. 手机怎么解决同ip多账号_抖音被限流,作品被判搬运,账号被判搬运限流,Dou?被封怎么办?...
  10. html判断表单是否为空,layui判断表单是否为空