Android自定义圆形进度条

 更新时间:2021年04月19日 09:47:21   作者:银伙计  
这篇文章主要为大家详细介绍了Android自定义圆形进度条的相关代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

今天小编来手写一个自定义圆形进度条:先看效果:

首先我们在attrs属性文件中增加几个自定义属性

<?xml version="1.0" encoding="utf-8"?>
<resources>

 <declare-styleable name="CustomProgressBar">
  <!-- 圆形进度条进度显示的颜色 -->
  <attr name="roundProgressColor" format="color"></attr>
  <!-- 外圈圆的颜色 -->
  <attr name="roundColor" format="color"></attr>
  <!-- 圆的总宽度 -->
  <attr name="roundWidth" format="dimension"></attr>
  <!-- 字体显示的大小 -->
  <attr name="textSize" format="dimension"></attr>
  <!-- 字体显示的颜色 -->
  <attr name="textColor" format="color"></attr>
  <!-- 进度的最大值 -->
  <attr name="max" format="integer"></attr>
  <!-- 是否显示文字 -->
  <attr name="textShow" format="boolean"></attr>
 </declare-styleable>

</resources>

上我们自定义类的实现代码:

package xxx.xxx.xxx;

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;
import android.graphics.Typeface;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.View;

import test.dn.com.dn_test.R;

/**
 * Created by Administrator on 2017/5/16 0016.
 */

public class CircleProgressBar extends View {

 private int max; //最大值
 private int roundColor; //圆形进度条的颜色
 private int roundProgressColor;//圆形进度条进度的颜色
 private int textColor;  //字体的颜色
 private float textSize;  //字体的大小
 private float roundWidth; //圆的宽度
 private boolean textShow; //是否显示圆
 private int progress; //当前进度
 private Paint mPaint; //画笔
 public static final int STROKE = 0;
 public static final int FILL = 1;

 public CircleProgressBar(Context context, @Nullable AttributeSet attrs) {
  super(context, attrs);
  //初始化一只笔
  mPaint = new Paint();
  //获取xml当中设置的属性,如果没有设置,则设置一个默认值
  TypedArray typedArray = context.obtainStyledAttributes(attrs , R.styleable.CustomProgressBar);
  max = typedArray.getInteger(R.styleable.CustomProgressBar_max , 100);
  roundColor = typedArray.getColor(R.styleable.CustomProgressBar_roundColor, Color.RED);
  roundProgressColor = typedArray.getColor(R.styleable.CustomProgressBar_roundProgressColor , Color.BLUE);
  textColor = typedArray.getColor(R.styleable.CustomProgressBar_textColor , Color.GREEN);
  textSize = typedArray.getDimension(R.styleable.CustomProgressBar_textSize , 55);
  roundWidth = typedArray.getDimension(R.styleable.CustomProgressBar_roundWidth , 10);
  textShow = typedArray.getBoolean(R.styleable.CustomProgressBar_textShow , true);

 }

 @Override
 protected void onDraw(Canvas canvas) {
  super.onDraw(canvas);
  //画背景圆环
  int center = getWidth() / 2;
  //设置半径
  float radius = center - roundWidth / 2;
  //设置圆圈的颜色
  mPaint.setColor(roundColor);
  mPaint.setStyle(Paint.Style.STROKE);
  mPaint.setStrokeWidth(roundWidth);//圆环的宽度
  mPaint.setAntiAlias(true);//设置抗锯齿

  //画外圈
  canvas.drawCircle(center , center ,radius , mPaint);

  //画进度百分比
  mPaint.setColor(textColor);
  mPaint.setStrokeWidth(0);
  //设置字体大小
  mPaint.setTextSize(textSize);
  mPaint.setTypeface(Typeface.DEFAULT);
  //设置笔帽
  mPaint.setStrokeCap(Paint.Cap.ROUND);
  //设置文字的摆放方式为居中
  mPaint.setTextAlign(Paint.Align.CENTER);
  //获取当前进度的值
  int percent = (int) (progress / (float)max * 100);
  String strPercent = percent + "%";
  //获取画笔的文字属性,总共有bottom , top , leading , ascent , descent 这个以后会详细讲解
  Paint.FontMetricsInt fm = mPaint.getFontMetricsInt();
  if(percent != 0){
   canvas.drawText(strPercent , getWidth() / 2 ,
     getWidth() / 2 + (fm.bottom - fm.top) / 2 - fm.bottom, mPaint);
  }
  //画圆弧
  RectF oval = new RectF(center - radius , center - radius ,center + radius , center + radius);
  mPaint.setColor(roundProgressColor);
  mPaint.setStrokeWidth(roundWidth);
  mPaint.setStyle(Paint.Style.STROKE);
  //设置笔帽
  mPaint.setStrokeCap(Paint.Cap.ROUND);
  //话进度
  canvas.drawArc(oval , 0 , 360 * progress / max , false , mPaint);
 }

 public void setProgress(int progress){
  if(progress < 0){
   throw new IllegalArgumentException("进度progress不能小于0");
  }
  if(progress > max){
   progress = max;
  }
  if(progress <= max){
   this.progress = progress;
   postInvalidate();
  }

 }
}

在我们的xml中设置控件:

 <xxx.xxx.CircleProgressBar
  android:id="@+id/progressbar"
  android:layout_width="100dp"
  android:layout_height="100dp"
  app:roundProgressColor="#ff00ff"
  app:textColor="#666666"
  app:textSize="20dp"
  app:roundWidth="15dp"
  />

Activity功能实现代码:

mProgressBar = (CircleProgressBar) findViewById(R.id.progressbar);
  mProgressBar.setOnClickListener(new View.OnClickListener() {
   @Override
   public void onClick(View v) {
    //模拟http请求
    new Thread(new Runnable() {
     @Override
     public void run() {
      while (progress <= 100){
       progress += 2;
       mProgressBar.setProgress(progress);
       //模拟网络请求,每隔100毫秒增加一个进度
       SystemClock.sleep(100);
      }
     }
    }).start();
   }
  });

完结!

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

相关文章

  • Android 应用签名的两种方法

    Android 应用签名的两种方法

    这篇文章主要介绍了Android 应用签名的两种方法的相关资料,这里提供了两种实现方法分别实现签名,希望能帮助到大家,需要的朋友可以参考下
    2017-08-08
  • Android布局加载之LayoutInflater示例详解

    Android布局加载之LayoutInflater示例详解

    这篇文章主要介绍了Android布局加载之LayoutInflater的相关资料,文中介绍的非常详细,对大家具有一定的参考借鉴价值,需要的朋友们下面来一起看看吧。
    2017-03-03
  • Android仿美团外卖菜单界面

    Android仿美团外卖菜单界面

    这篇文章主要为大家详细介绍了Android仿美团外卖菜单界面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • Android中库项目的使用方法图文介绍

    Android中库项目的使用方法图文介绍

    类似开发其他Java应用一样,我们可以将可复用的代码,打成一个jar包,供所有需要的项目使用。这样,可以解决很大一部分代码复用的问题,本文将详细介绍,需要了解的朋友可以参考下
    2012-12-12
  • Android架构发展进化详解

    Android架构发展进化详解

    Android系统架构从上到下分为五层:应用层、应用框架层、系统运行库层、硬件抽象层、Linux内核层,Android架构也经历了多次演进,下面我们来详细了解一下
    2022-08-08
  • Android Volley框架使用源码分享

    Android Volley框架使用源码分享

    这篇文章主要为大家分享了详细的Android Volley框架使用流程源码,具有参考价值,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • Android开发之Adobe flash操作工具类

    Android开发之Adobe flash操作工具类

    这篇文章主要介绍了Android开发之Adobe flash操作工具类,可实现flash的安装及判断flash是否安装等功能,需要的朋友可以参考下
    2017-12-12
  • Kotlin中标准函数run、with、let、also与apply的使用和区别详解

    Kotlin中标准函数run、with、let、also与apply的使用和区别详解

    相比Java, Kotlin提供了不少高级语法特性。对于一个Kotlin的初学者来说经常会写出一些不够优雅的代码,下面这篇文章主要给大家介绍了关于Kotlin中标准函数run、with、let、also与apply的使用和区别的相关资料,需要的朋友可以参考下。
    2018-03-03
  • Android计时器控件Chronometer应用实例

    Android计时器控件Chronometer应用实例

    这篇文章主要为大家详细介绍了Android计时器控件Chronometer应用实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-09-09
  • Android Service启动流程刨析

    Android Service启动流程刨析

    这几天分析了一下的启动过程,于是乎,今天写一下Service是如何启动的; 给我的感觉是这些启动过程并不复杂,千万不要被一坨一坨的代码吓住了,虽然弯弯绕绕不少,重载函数一个接着一个,就向走迷宫一样,但只要抓住主线阅读,很快就能找到出口
    2022-08-08

最新评论