热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android自定义圆形进度条

这篇文章主要为大家详细介绍了Android自定义圆形进度条的相关代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

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

<&#63;xml version="1.0" encoding="utf-8"&#63;>


 
  
  
  
  
  
  
  
  
  
  
  
  
  
  
 


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

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中设置控件:

 

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 的 TextView 添加圆形边框。我们将详细讲解 XML 代码的配置,包括圆角、描边和填充等属性。 ... [详细]
  • JavaScript 中创建对象的多种方式
    本文介绍了 JavaScript 中创建对象的几种常见方法,包括字面量形式、构造函数、原型对象等。每种方法都有其特点和适用场景,通过对比分析,帮助开发者选择最适合的方式。 ... [详细]
  • 本文探讨了在使用Selenium进行自动化测试时,由于webdriver对象实例化位置不同而导致浏览器闪退的问题,并提供了详细的代码示例和解决方案。 ... [详细]
  • 本文介绍如何将自定义项目设置为Tomcat的默认访问项目,使得通过IP地址访问时直接展示该自定义项目。提供了三种配置方法:修改项目路径、调整配置文件以及使用WAR包部署。 ... [详细]
  • 算法题解析:最短无序连续子数组
    本题探讨如何通过单调栈的方法,找到一个数组中最短的需要排序的连续子数组。通过正向和反向遍历,分别使用单调递增栈和单调递减栈来确定边界索引,从而定位出最小的无序子数组。 ... [详细]
  • 本文深入探讨了线性代数中向量的线性关系,包括线性相关性和极大线性无关组的概念。通过分析线性方程组和向量组的秩,帮助读者理解这些概念在实际问题中的应用。 ... [详细]
  • 本文介绍如何在 C++ 中使用链表结构存储和管理数据。通过具体示例,展示了静态链表的基本操作,包括节点的创建、链接及遍历。 ... [详细]
  • 本文旨在提供一套高效的面试方法,帮助企业在短时间内找到合适的产品经理。虽然观点较为直接,但其方法已被实践证明有效,尤其适用于初创公司和新项目的需求。 ... [详细]
  • 本文探讨了使用C#在SQL Server和Access数据库中批量插入多条数据的性能差异。通过具体代码示例,详细分析了两种数据库的执行效率,并提供了优化建议。 ... [详细]
  • 反向投影技术主要用于在大型输入图像中定位特定的小型模板图像。通过直方图对比,它能够识别出最匹配的区域或点,从而确定模板图像在输入图像中的位置。 ... [详细]
  • 本问题探讨了在特定条件下排列儿童队伍的方法数量。题目要求计算满足条件的队伍排列总数,并使用递推算法和大数处理技术来解决这一问题。 ... [详细]
  • 解决Anaconda安装TensorFlow时遇到的TensorBoard版本问题
    本文介绍了在使用Anaconda安装TensorFlow时遇到的“Could not find a version that satisfies the requirement tensorboard”错误,并提供详细的解决方案,包括创建虚拟环境和配置PyCharm项目。 ... [详细]
  • 如何将本地Docker镜像推送到阿里云容器镜像服务
    本文详细介绍将本地Docker镜像上传至阿里云容器镜像服务的步骤,包括登录、查看镜像列表、推送镜像以及确认上传结果。通过本文,您将掌握如何高效地管理Docker镜像并将其存储在阿里云的镜像仓库中。 ... [详细]
  • 在创建新的Android项目时,您可能会遇到aapt错误,提示无法打开libstdc++.so.6共享对象文件。本文将探讨该问题的原因及解决方案。 ... [详细]
  • 在使用STM32Cube进行定时器配置时,有时会遇到延时不准的问题。本文探讨了可能导致延时不准确的原因,并提供了解决方法和预防措施。 ... [详细]
author-avatar
国邮国旅刘峰
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有