直接上源码
package com.androiddemo; 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.util.AttributeSet; import android.util.TypedValue; import android.view.View; public class CustomProgressBar extends View implements Runnable { private int mFirstColor;// 第一圈的颜色 private int mSecondColor;// 第二圈的颜色 private int mCircleWidth;// 圈的宽度 private Paint mPaint;// 画笔 private int mProgress;// 当前进度 private int mSpeed;// 速度 private boolean isNext;// 是否应该开始下一个 private float centre; // 获取圆心的x坐标 private float radius;// 半径 private RectF oval; public CustomProgressBar(Context context, AttributeSet attrs) { this(context, attrs, 0); // 绘图线程 new Thread(this).start(); } /** * 必要的初始化,获得一些自定义的值 * * @param context * @param attrs * @param defStyle */ public CustomProgressBar(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.CustomProgressBar, defStyle, 0); int n = a.getIndexCount(); for (int i = 0; i < n; i++) { int attr = a.getIndex(i); switch (attr) { case R.styleable.CustomProgressBar_firstColor: mFirstColor = a.getColor(attr, Color.GREEN); break; case R.styleable.CustomProgressBar_secondColor: mSecondColor = a.getColor(attr, Color.RED); break; case R.styleable.CustomProgressBar_circleWidth: mCircleWidth = a.getDimensionPixelSize(attr, (int) TypedValue .applyDimension(TypedValue.COMPLEX_UNIT_PX, 20, getResources().getDisplayMetrics())); break; case R.styleable.CustomProgressBar_speed: mSpeed = a.getInt(attr, 20);// 默认20 break; } } a.recycle(); mPaint = new Paint(Paint.ANTI_ALIAS_FLAG); } @Override protected void onLayout(boolean changed, int left, int top, int right, int bottom) { // TODO Auto-generated method stub super.onLayout(changed, left, top, right, bottom); if (centre == 0) { centre = getWidth() / 2; // 获取圆心的x坐标 radius = centre - mCircleWidth / 2;// 半径 oval = new RectF(centre - radius, centre - radius, centre + radius, centre + radius); // 用于定义的圆弧的形状和大小的界限 } } @Override protected void onDraw(Canvas canvas) { mPaint.setStrokeWidth(mCircleWidth); // 设置圆环的宽度 mPaint.setStyle(Paint.Style.STROKE); // 设置空心 if (!isNext) {// 第一颜色的圈完整,第二颜色跑 mPaint.setColor(mFirstColor); // 设置圆环的颜色 canvas.drawCircle(centre, centre, radius, mPaint); // 画出圆环 mPaint.setColor(mSecondColor); // 设置圆环的颜色 canvas.drawArc(oval, -90, mProgress, false, mPaint); // 根据进度画圆弧 } else { mPaint.setColor(mSecondColor); // 设置圆环的颜色 canvas.drawCircle(centre, centre, radius, mPaint); // 画出圆环 mPaint.setColor(mFirstColor); // 设置圆环的颜色 canvas.drawArc(oval, -90, mProgress, false, mPaint); // 根据进度画圆弧 } } @Override public void run() { // TODO Auto-generated method stub while (true) { mProgress++; if (mProgress == 360) { mProgress = 0; isNext = !isNext; } postInvalidate(); try { Thread.sleep(mSpeed); } catch (InterruptedException e) { e.printStackTrace(); } } } }
attrs.xml
<?xml version="1.0" encoding="utf-8"?> <resources> <attr name="firstColor" format="color" /> <attr name="secondColor" format="color" /> <attr name="circleWidth" format="dimension" /> <attr name="speed" format="integer" /> <declare-styleable name="CustomProgressBar"> <attr name="firstColor" /> <attr name="secondColor" /> <attr name="circleWidth" /> <attr name="speed" /> </declare-styleable> </resources>
布局文件
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" xmlns:mand="http://schemas.android.com/apk/res/com.androiddemo" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity" > <com.androiddemo.CustomProgressBar android:layout_width="200dp" android:layout_height="200dp" android:layout_centerInParent="true" android:layout_marginBottom="40dp" mand:circleWidth="24dp" mand:firstColor="#16A3FA" mand:secondColor="#D20F02" mand:speed="2" /> </RelativeLayout>
收藏的用户(0) X
正在加载信息~
推荐阅读
最新回复 (0)
站点信息
- 文章2302
- 用户1336
- 访客10962994
每日一句
Progress starts with one brave step forward.
进步始于一次勇敢的迈步。
进步始于一次勇敢的迈步。
新会员