Android自定義View實現(xiàn)圓環(huán)進度條
本文實例為大家分享了Android自定義View實現(xiàn)圓環(huán)進度條的具體代碼,供大家參考,具體內(nèi)容如下
效果展示
動畫效果

View實現(xiàn)
1.底層圓環(huán)是灰色背景
2.上層圓環(huán)是紅色背景
3.使用動畫畫一條弧線
View
/**
* 圓環(huán)進度條
*/
public class RoundProgressBar extends View {
//繪制矩形區(qū)域
private RectF rectF;
//起始角度
private float startAngle;
//掃過角度
private float sweepAngle;
//畫筆
private Paint paint;
//默認控件大小
private int defoutSize;
//默認線條寬度
private int defoutLine;
private int strokeWidth;
private PointF pointF = new PointF();
public RoundProgressBar(Context context) {
super(context);
initData();
}
public RoundProgressBar(Context context, AttributeSet attrs) {
super(context, attrs);
initData();
}
/**
* 參數(shù)初始化
*/
private void initData() {
startAngle = 0;
sweepAngle = 0;
defoutSize = 400;
defoutLine = 20;
strokeWidth = 20;
rectF = new RectF();
//抗鋸齒畫筆
paint = new Paint(Paint.ANTI_ALIAS_FLAG);
paint.setColor(Color.GRAY);
paint.setStrokeWidth(defoutLine);
//筆帽樣式
paint.setStrokeCap(Paint.Cap.ROUND);
paint.setStyle(Paint.Style.STROKE);
}
/**
* xml -----> 提供可繪制位置
*
* @param widthMeasureSpec 寬
* @param heightMeasureSpec 高
*/
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
setMeasuredDimension(defoutSize, defoutSize);
}
/**
* 當大小時改變回調(diào)
*
* @param w
* @param h
* @param oldw
* @param oldh
*/
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
super.onSizeChanged(w, h, oldw, oldh);
pointF.x = w >> 1;
pointF.y = h >> 1;
rectF.top = strokeWidth >> 1;
rectF.bottom = h - (strokeWidth >> 1);
rectF.left = strokeWidth >> 1;
rectF.right = w - (strokeWidth >> 1);
}
/**
* 繪制
*
* @param canvas
*/
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
//畫布旋轉(zhuǎn)
paint.setColor(Color.GRAY);
canvas.rotate(135, pointF.x, pointF.y);
//繪制圓環(huán)
canvas.drawArc(rectF, startAngle, 270, false, paint);
paint.setColor(Color.RED);
canvas.drawArc(rectF, startAngle, sweepAngle, false, paint);
}
public void setProgress(float index) {
//防止數(shù)值越界
if (index > 1 || index < 0) {
return;
}
ValueAnimator valueAnimator = ValueAnimator.ofFloat(0, index);
valueAnimator.setDuration(3000);
valueAnimator.setInterpolator(new DecelerateInterpolator());
valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator animation) {
sweepAngle = (float) animation.getAnimatedValue() * 270;
//重寫繪制
invalidate();
}
});
valueAnimator.start();
}
}
最后在Activity中使用setProgress方法賦值進度條的進度來實現(xiàn)效果
progressView.setProgress(0.8f);
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- android自定義進度條漸變色View的實例代碼
- Android中實現(xiàn)Webview頂部帶進度條的方法
- android ListView和ProgressBar(進度條控件)的使用方法
- Android自定義View實現(xiàn)漸變色進度條
- Android中WebView加載網(wǎng)頁設(shè)置進度條
- Android自定義View實現(xiàn)帶數(shù)字的進度條實例代碼
- Android Webview添加網(wǎng)頁加載進度條實例詳解
- Android自定義View實現(xiàn)水平帶數(shù)字百分比進度條
- Android自定義圓環(huán)式進度條
- Android自定義view實現(xiàn)圓環(huán)進度條效果
相關(guān)文章
Android計時與倒計時實現(xiàn)限時搶購的5種方法
這篇文章主要為大家詳細介紹了Android計時與倒計時實現(xiàn)限時搶購的5種方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-02-02
Android編程自定義AlertDialog樣式的方法詳解
這篇文章主要介紹了Android編程自定義AlertDialog樣式的方法,結(jié)合實例形式詳細分析了Android自定義AlertDialog樣式的具體布局與功能實現(xiàn)相關(guān)操作技巧,需要的朋友可以參考下2018-02-02
android 實現(xiàn)類似微信緩存和即時更新好友頭像示例
本篇文章主要介紹了android 實現(xiàn)類似微信緩存和即時更新好友頭像示例,具有一定的參考價值,有興趣的可以了解一下。2017-01-01
Android?中?FrameLayout?布局及屬性的使用詳解
這篇文章主要介紹了Android?中?FrameLayout?布局及屬性的使用,FrameLayout?在實現(xiàn)簡單布局時非常方便,特別適用于疊加式布局,如顯示疊加的圖層或浮動按鈕等,需要的朋友可以參考下2024-03-03
Android編程實現(xiàn)切換imageView的方法分析
這篇文章主要介紹了Android編程實現(xiàn)切換imageView的方法,結(jié)合具體實例形式分析了切換imageView的相關(guān)設(shè)置技巧與注意事項,需要的朋友可以參考下2017-09-09
Android應(yīng)用程序轉(zhuǎn)到后臺并回到前臺判斷方法
這篇文章主要介紹了Android應(yīng)用程序轉(zhuǎn)到后臺并回到前臺判斷方法的相關(guān)資料,需要的朋友可以參考下2016-11-11
Android ListView列表優(yōu)化的方法詳解
列表 ListView 是應(yīng)用中最為常見的組件,而列表往往也會承載很多元素,這時就需要對其進行優(yōu)化。本文介紹了 Flutter ListView 的4個優(yōu)化要點,非常實用,需要的可以參考一下2022-05-05
Android手勢密碼--設(shè)置和校驗功能的實現(xiàn)代碼
這篇文章主要介紹了Android手勢密碼--設(shè)置和校驗功能的實現(xiàn)代碼,非常不錯,具有一定的參考校驗價值,需要的朋友可以參考下2018-05-05

