圆形进度条:简单实现倒计时圆形进度条

  • 上一个4秒的效果图:

  • 添加依赖

   implementation 'com.dinuscxj:circleprogressbar:1.3.6'
  • 布局完整代码:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <com.dinuscxj.progressbar.CircleProgressBar
        android:id="@+id/cpb"
        android:layout_width="80dp"
        android:layout_height="80dp"
        app:progress_stroke_cap="round"
        app:progress_stroke_width="5dp"
        app:progress_style="solid_line"
        app:progress_start_color="#00391F"
        app:progress_end_color="#00391F"
        android:layout_centerInParent="true"
        />

</RelativeLayout>
  • MainActivity.java完整代码:
public class MainActivity extends AppCompatActivity {
    CircleProgressBar cpb;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        cpb = findViewById(R.id.cpb);
        cpb.setProgressFormatter(null);
        simulateProgress();

    }

    private void simulateProgress() {
        ValueAnimator animator = ValueAnimator.ofInt(0, 100);
        animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
            @Override
            public void onAnimationUpdate(ValueAnimator animation) {
                int progress = (int) animation.getAnimatedValue();
                cpb.setProgress(progress);
            }
        });
        animator.setRepeatCount(ValueAnimator.INFINITE);
        Interpolator linearInterpolator = new LinearInterpolator(); //匀速
        animator.setInterpolator(linearInterpolator);

        animator.setDuration(4 * 1000);
        animator.start();
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangjin1120

可靠的文章费时费力,希望支持

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值