自定义圆形进度条



    Paint paint;


    int mcolor = Color.RED;
    /**
     * 圈的宽度
     */
    private int mCircleWidth = 10;


    float currentPoint;
    private ValueAnimator anim;






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


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


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


    private void init() {


        paint = new Paint();
        paint.setAntiAlias(true);
    }




    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);


        paint.setStyle(Paint.Style.STROKE);
        int centre = getWidth() / 2; // 获取圆心的x坐标
        int radius = centre - mCircleWidth / 2;// 半径
        paint.setStrokeWidth(mCircleWidth); // 设置圆环的宽度
        paint.setColor(Color.BLACK); // 设置圆环的颜色
        RectF oval = new RectF(centre - radius, centre - radius, centre + radius, centre + radius); // 用于定义的圆弧的形状和大小的界限


        canvas.drawCircle(centre, centre, radius, paint); // 画出圆环


        paint.setColor(mcolor); // 设置圆环的颜色








        canvas.drawArc(oval, -90, currentPoint, false, paint); // 根据进度画圆弧


        paint.setStyle(Paint.Style.FILL);
        paint.setTextSize(40);
        float v = paint.measureText("78%");


        canvas.drawText("78%",centre-v/2,centre+10,paint);
        if (currentPoint == 0){
            startAnimation();
        }


    }


    private void startAnimation(){
        anim = ValueAnimator.ofFloat(0,360);
        anim.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
            @Override
            public void onAnimationUpdate(ValueAnimator valueAnimator) {
                currentPoint = (float) valueAnimator.getAnimatedValue();
                invalidate();
            }
        });
        anim.setDuration(30000);
    }


    public void start(){
        anim.start();
    }




    @RequiresApi(api = Build.VERSION_CODES.KITKAT)
    public void resatrt(){
        anim.resume();
        anim.start();
    }




    public void set(int color){


            mcolor = color;


    }



public class MainActivity extends AppCompatActivity {


    private MyView mv;
    private List<Integer> list;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //开始
        Button start = (Button) findViewById(R.id.start);
        //重置
        Button restart = (Button) findViewById(R.id.restart);


        TextView tv = (TextView) findViewById(R.id.tv);
        //自定义控件
        mv = (MyView) findViewById(R.id.mv);


        list = new ArrayList<>();
        list.add(Color.BLUE);
        list.add(Color.RED);
        list.add(Color.GRAY);
        list.add(Color.GREEN);
        list.add(Color.WHITE);


        tv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                int num = (int) (Math.random()*5);
                System.out.println("==="+num);
                mv.set(list.get(num));
            }
        });


        //点击开始
        start.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                mv.start();
            }
        });


        //点击重置
        restart.setOnClickListener(new View.OnClickListener() {
            @RequiresApi(api = Build.VERSION_CODES.KITKAT)
            @Override
            public void onClick(View view) {
                mv.resatrt();
            }
        });








    }
}


<TextView
        android:id="@+id/tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="改变外层圆环颜色"
        />
    <com.bwie.test.MyView
        android:id="@+id/mv"
        android:layout_margin="50dp"
        android:layout_width="200dp"
        android:layout_height="200dp" />


    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">
        <Button
            android:id="@+id/start"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="开始"/>
        <Button
            android:id="@+id/restart"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="重置"/>
    </LinearLayout>





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值