Android自定义View实现圆环进度条

 更新时间:2020年05月29日 10:08:54   作者:汪星没有熊  
这篇文章主要为大家详细介绍了Android自定义View实现圆环进度条,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了Android自定义View实现圆环进度条的具体代码,供大家参考,具体内容如下

效果展示

动画效果

View实现

1.底层圆环是灰色背景
2.上层圆环是红色背景
3.使用动画画一条弧线

View

/**
 * 圆环进度条
 */
public class RoundProgressBar extends View {
 //绘制矩形区域
 private RectF rectF;
 //起始角度
 private float startAngle;
 //扫过角度
 private float sweepAngle;
 //画笔
 private Paint paint;
 //默认控件大小
 private int defoutSize;
 //默认线条宽度
 private int defoutLine;
 private int strokeWidth;

 private PointF pointF = new PointF();


 public RoundProgressBar(Context context) {
  super(context);
  initData();
 }

 public RoundProgressBar(Context context, AttributeSet attrs) {
  super(context, attrs);
  initData();
 }

 /**
  * 参数初始化
  */
 private void initData() {
  startAngle = 0;
  sweepAngle = 0;
  defoutSize = 400;
  defoutLine = 20;
  strokeWidth = 20;

  rectF = new RectF();

  //抗锯齿画笔
  paint = new Paint(Paint.ANTI_ALIAS_FLAG);
  paint.setColor(Color.GRAY);
  paint.setStrokeWidth(defoutLine);
  //笔帽样式
  paint.setStrokeCap(Paint.Cap.ROUND);
  paint.setStyle(Paint.Style.STROKE);
 }

 /**
  * xml -----> 提供可绘制位置
  *
  * @param widthMeasureSpec 宽
  * @param heightMeasureSpec 高
  */
 @Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  super.onMeasure(widthMeasureSpec, heightMeasureSpec);
  setMeasuredDimension(defoutSize, defoutSize);
 }

 /**
  * 当大小时改变回调
  *
  * @param w
  * @param h
  * @param oldw
  * @param oldh
  */
 @Override
 protected void onSizeChanged(int w, int h, int oldw, int oldh) {
  super.onSizeChanged(w, h, oldw, oldh);

  pointF.x = w >> 1;
  pointF.y = h >> 1;

  rectF.top = strokeWidth >> 1;
  rectF.bottom = h - (strokeWidth >> 1);
  rectF.left = strokeWidth >> 1;
  rectF.right = w - (strokeWidth >> 1);

 }

 /**
  * 绘制
  *
  * @param canvas
  */
 @Override
 protected void onDraw(Canvas canvas) {
  super.onDraw(canvas);

  //画布旋转
  paint.setColor(Color.GRAY);
  canvas.rotate(135, pointF.x, pointF.y);
  //绘制圆环
  canvas.drawArc(rectF, startAngle, 270, false, paint);

  paint.setColor(Color.RED);
  canvas.drawArc(rectF, startAngle, sweepAngle, false, paint);

 }

 public void setProgress(float index) {
 //防止数值越界
  if (index > 1 || index < 0) {
   return;
  }
  ValueAnimator valueAnimator = ValueAnimator.ofFloat(0, index);
  valueAnimator.setDuration(3000);
  valueAnimator.setInterpolator(new DecelerateInterpolator());
  valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
   @Override
   public void onAnimationUpdate(ValueAnimator animation) {
    sweepAngle = (float) animation.getAnimatedValue() * 270;
    //重写绘制
    invalidate();
   }
  });
  valueAnimator.start();

 }
}

最后在Activity中使用setProgress方法赋值进度条的进度来实现效果

progressView.setProgress(0.8f);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android实现读取NFC卡卡号示例

    Android实现读取NFC卡卡号示例

    本篇文章主要介绍了Android实现读取NFC卡卡号示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • flutter text组件使用示例详解

    flutter text组件使用示例详解

    这篇文章主要为大家介绍了flutter text组件使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • android 触屏的震动响应接口调用方法

    android 触屏的震动响应接口调用方法

    android 相关开发过程中,经常会使用到触屏的震动响应接口,为此本文列出以下方法,想要了解的朋友可以参考下
    2012-11-11
  • 解决PhoneGap不支持viewport的几种方法

    解决PhoneGap不支持viewport的几种方法

    今天小编就为大家分享一篇关于解决PhoneGap不支持viewport的几种方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • android中使用SharedPreferences进行数据存储的操作方法

    android中使用SharedPreferences进行数据存储的操作方法

    本篇文章介绍了,在android中使用SharedPreferences进行数据存储的操作方法。需要的朋友参考下
    2013-04-04
  • Android开发gradle拉取依赖的加速配置

    Android开发gradle拉取依赖的加速配置

    这篇文章主要为大家介绍了Android开发gradle拉取依赖的加速配置,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • Android 内存溢出和内存泄漏的问题

    Android 内存溢出和内存泄漏的问题

    这篇文章主要介绍了Android 内存溢出和内存泄漏的问题的相关资料,需要的朋友可以参考下
    2017-03-03
  • 安卓Android Context类实例详解

    安卓Android Context类实例详解

    在开发Android的过程中,总是能遇见Context类或者它的实例.Context类的实例经常被用来提供“应用程序”的引用,下面举例说明Contex类实例详解
    2016-07-07
  • Android编程设计模式之访问者模式详解

    Android编程设计模式之访问者模式详解

    这篇文章主要介绍了Android编程设计模式之访问者模式,详细分析了访问者模式的概念、功能、原理、使用场景并结合实例形式给出了Android访问者模式的具体实现技巧与相关操作注意事项,需要的朋友可以参考下
    2017-12-12
  • Android实现面包屑功能的代码(支持Fragment联动)

    Android实现面包屑功能的代码(支持Fragment联动)

    这篇文章主要介绍了Android实现面包屑功能的代码(支持Fragment联动),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-05-05

最新评论