Android自定义View——环形进度条

本文介绍了如何在Android中自定义一个环形进度条,包括圆环背景、圆环进度和加载动画的实现。文章详细讲解了自定义View的构造方法、初始化过程、重写`onDraw`方法进行绘制,并提到了如何添加渐进动画效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

自定义View

让我们先从一个简单的例子入手:
环形进度条
一个简单的环形进度条,在进度条前端位置加一个白色小圆点,然后还有一个进度加载动画。

首先我们分析一下这个自定义View包含了以下几个部分:

  • 圆环背景
  • 圆环进度
  • 白色小圆点
  • 加载动画

大概就只有这几个部分组成。

第一步:首先我们要新建一个自定义的类继承系统的View类:

public class CircleProgress extends View {
   
   
    private static final String TAG = "CircleProgress";

    public CircleProgress(Context context) {
   
   
        super(context);
        init();
    }

    public CircleProgress(Context context, @Nullable AttributeSet attrs) {
   
   
        super(context, attrs);
        init();
    }

    public CircleProgress(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
   
   
        super(context, attrs, defStyleAttr);
        init();
    }
 
    private void init(){
   
   
        //初始化操作
    }
}

需要注意的是:

1、其中还有一个构造方法

public ProgressView(Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {
   
   
        super(context, attrs, defStyleAttr, defStyleRes);
    }

因为这个构造方法需要至少API21才能支持,所以我们不使用。

2、在每个构造方法中我们都需要调用init()方法来初始化我们的view。

3、除了上面代码中所展示的构造方法的写法,还有另一种方式:

public class CircleProgress extends View {
   
   
    public CircleProgress(Context context) {
   
   
        this(context,null);
    }

    public CircleProgress(Context context, @Nullable AttributeSet attrs) {
   
   
        this(context
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值