日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Android自定義控件之圓形進度條動畫

瀏覽:43日期:2022-09-23 13:06:47

本文實例為大家分享了Android實現圓形進度條動畫的具體代碼,供大家參考,具體內容如下

首先貼上圖片:

Android自定義控件之圓形進度條動畫

額,感覺還行吧,就是進度條的顏色丑了點,不過咱是程序員,不是美工,配色這種問題當然不在考慮范圍之內了。

下面說重點,如何來寫一個這樣的自定義控件。

首先,需要有一個灰色的底圖,來作為未填充時的進度條;

然后,根據傳入的當前進度值,繪制填充時的進度圓弧,這段圓弧所對應的圓心角,由當前進度與進度的最大值(一般是100)的比值計算得出;

其次,根據進度值繪制文字提示;

最后,重繪控件,加上動畫,從而達到顯示進度的效果。

代碼如下:

1、attrs.xml

<?xml version='1.0' encoding='utf-8'?><resources> <declare-styleable name='circleProgressBar'> <attr name='circleWidth' format='dimension' /> <attr name='betaAngle' format='integer' /> <attr name='firstColor' format='color' /> <attr name='secondColor' format='color' /> </declare-styleable> </resources>

2、CircleProgressBar.java

package com.ctgu.circleprogressbar; import android.animation.ValueAnimator;import android.content.Context;import android.content.res.TypedArray;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.LinearGradient;import android.graphics.Paint;import android.graphics.Paint.FontMetricsInt;import android.graphics.Rect;import android.graphics.RectF;import android.graphics.Shader;import android.util.AttributeSet;import android.util.TypedValue;import android.view.View;import android.view.animation.OvershootInterpolator; public class CircleProgressBar extends View{ /** * 進度條最大值,默認為100 */ private int maxValue = 100; /** * 當前進度值 */ private int currentValue = 0; /** * 每次掃過的角度,用來設置進度條圓弧所對應的圓心角,alphaAngle=(currentValue/maxValue)*360 */ private float alphaAngle; /** * 底部圓弧的顏色,默認為Color.LTGRAY */ private int firstColor; /** * 進度條圓弧塊的顏色 */ private int secondColor; /** * 圓環的寬度 */ private int circleWidth; /** * 畫圓弧的畫筆 */ private Paint circlePaint; /** * 畫文字的畫筆 */ private Paint textPaint; /** * 漸變圓周顏色數組 */ private int[] colorArray = new int[] { Color.parseColor('#27B197'), Color.parseColor('#00A6D5') };// /** * 通過代碼創建時才使用 * * @param context */ public CircleProgressBar(Context context) { this(context, null); } /** * 當從xml中加載view的時候,這個構造器才會被調用。其第二個參數中就包含自定義的屬性。 * * @param context * 上下文 * @param attrs * 自定義屬性 */ public CircleProgressBar(Context context, AttributeSet attrs) { this(context, attrs, 0); } /** * 從xml加載時執行和應用一個特定的風格。這里有兩種方式,一是從theme中獲得,二是從style中獲得。 * 第三個參數官方有這樣的說明: defStyle - The default style to apply to this view. If 0, * no style will be applied (beyond what is included in the theme). This may * either be an attribute resource, whose value will be retrieved from the * current theme, or an explicit style resource. * 默認的風格會被應用到這個view上。如果是0,沒有風格將會被應用 * (除了被包含在主題中)。這個也許是一個屬性的資源,它的值是從當前的主題中檢索,或者是一個明確的風格資源。 * * @param context * 上下文 * @param attrs * 自定義的屬性 * @param defStyleAttr * 自定義風格 */ public CircleProgressBar(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); TypedArray ta = context.getTheme().obtainStyledAttributes(attrs, R.styleable.circleProgressBar, defStyleAttr, 0); int n = ta.getIndexCount(); for (int i = 0; i < n; i++) { int attr = ta.getIndex(i); switch (attr) { case R.styleable.circleProgressBar_firstColor: firstColor = ta.getColor(attr, Color.LTGRAY); // 默認底色為亮灰色 break; case R.styleable.circleProgressBar_secondColor: secondColor = ta.getColor(attr, Color.BLUE); // 默認進度條顏色為藍色 break; case R.styleable.circleProgressBar_circleWidth: circleWidth = ta.getDimensionPixelSize(attr, (int) TypedValue.applyDimension( TypedValue.COMPLEX_UNIT_DIP, 6, getResources().getDisplayMetrics())); // 默認圓弧寬度為6dp break; default: break; } } ta.recycle(); circlePaint = new Paint(); circlePaint.setAntiAlias(true); // 抗鋸齒 circlePaint.setDither(true); // 防抖動 circlePaint.setStrokeWidth(circleWidth); textPaint = new Paint(); textPaint.setAntiAlias(true); textPaint.setDither(true); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {// 分別獲取期望的寬度和高度,并取其中較小的尺寸作為該控件的寬和高 int measureWidth = MeasureSpec.getSize(widthMeasureSpec); int measureHeight = MeasureSpec.getSize(heightMeasureSpec); setMeasuredDimension(Math.min(measureWidth, measureHeight), Math.min(measureWidth, measureHeight)); } @Override protected void onDraw(Canvas canvas) { int center = this.getWidth() / 2; int radius = center - circleWidth / 2; drawCircle(canvas, center, radius); // 繪制進度圓弧 drawText(canvas, center, radius); } /** * 繪制進度圓弧 * * @param canvas * 畫布對象 * @param center * 圓心的x和y坐標 * @param radius * 圓的半徑 */ private void drawCircle(Canvas canvas, int center, int radius) { circlePaint.setShader(null); // 清除上一次的shader circlePaint.setColor(firstColor); // 設置底部圓環的顏色,這里使用第一種顏色 circlePaint.setStyle(Paint.Style.STROKE); // 設置繪制的圓為空心 canvas.drawCircle(center, center, radius, circlePaint); // 畫底部的空心圓 RectF oval = new RectF(center - radius, center - radius, center + radius, center + radius); // 圓的外接正方形 // 繪制顏色漸變圓環 // shader類是Android在圖形變換中非常重要的一個類。Shader在三維軟件中我們稱之為著色器,其作用是來給圖像著色。 LinearGradient linearGradient = new LinearGradient(circleWidth, circleWidth, getMeasuredWidth() - circleWidth, getMeasuredHeight() - circleWidth, colorArray, null, Shader.TileMode.MIRROR); circlePaint.setShader(linearGradient); circlePaint.setShadowLayer(10, 10, 10, Color.RED); circlePaint.setColor(secondColor); // 設置圓弧的顏色 circlePaint.setStrokeCap(Paint.Cap.ROUND); // 把每段圓弧改成圓角的 alphaAngle = currentValue * 360.0f / maxValue * 1.0f; // 計算每次畫圓弧時掃過的角度,這里計算要注意分母要轉為float類型,否則alphaAngle永遠為0 canvas.drawArc(oval, -90, alphaAngle, false, circlePaint); } /** * 繪制文字 * * @param canvas * 畫布對象 * @param center * 圓心的x和y坐標 * @param radius * 圓的半徑 */ private void drawText(Canvas canvas, int center, int radius) { float result = (currentValue * 100.0f / maxValue * 1.0f); // 計算進度 String percent = String.format('%.1f', result) + '%'; textPaint.setTextAlign(Paint.Align.CENTER); // 設置文字居中,文字的x坐標要注意 textPaint.setColor(Color.BLACK); // 設置文字顏色 textPaint.setTextSize(40); // 設置要繪制的文字大小 textPaint.setStrokeWidth(0); // 注意此處一定要重新設置寬度為0,否則繪制的文字會重疊 Rect bounds = new Rect(); // 文字邊框 textPaint.getTextBounds(percent, 0, percent.length(), bounds); // 獲得繪制文字的邊界矩形 FontMetricsInt fontMetrics = textPaint.getFontMetricsInt(); // 獲取繪制Text時的四條線 int baseline = center + (fontMetrics.bottom - fontMetrics.top) / 2 - fontMetrics.bottom; // 計算文字的基線,方法見http://blog.csdn.net/harvic880925/article/details/50423762 canvas.drawText(percent, center, baseline, textPaint); // 繪制表示進度的文字 } /** * 設置圓環的寬度 * * @param width */ public void setCircleWidth(int width) { this.circleWidth = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, width, getResources() .getDisplayMetrics()); circlePaint.setStrokeWidth(circleWidth); invalidate(); } /** * 設置圓環的底色,默認為亮灰色LTGRAY * * @param color */ public void setFirstColor(int color) { this.firstColor = color; circlePaint.setColor(firstColor); invalidate(); } /** * 設置進度條的顏色,默認為藍色<br> * * @param color */ public void setSecondColor(int color) { this.secondColor = color; circlePaint.setColor(secondColor); invalidate(); } /** * 設置進度條漸變色顏色數組 * * @param colors * 顏色數組,類型為int[] */ public void setColorArray(int[] colors) { this.colorArray = colors; invalidate(); } /** * 按進度顯示百分比 * * @param progress * 進度,值通常為0到100 */ public void setProgress(int progress) { int percent = progress * maxValue / 100; if (percent < 0) { percent = 0; } if (percent > 100) { percent = 100; } this.currentValue = percent; invalidate(); } /** * 按進度顯示百分比,可選擇是否啟用數字動畫 * * @param progress * 進度,值通常為0到100 * @param useAnimation * 是否啟用動畫,true為啟用 */ public void setProgress(int progress, boolean useAnimation) { int percent = progress * maxValue / 100; if (percent < 0) { percent = 0; } if (percent > 100) { percent = 100; } if (useAnimation) // 使用動畫 { ValueAnimator animator = ValueAnimator.ofInt(0, percent); animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animation) { currentValue = (int) animation.getAnimatedValue(); invalidate(); } }); animator.setInterpolator(new OvershootInterpolator()); animator.setDuration(1000); animator.start(); } else { setProgress(progress); } }}

3、activity_main.xml

<RelativeLayout xmlns:android='http://schemas.android.com/apk/res/android' xmlns:tools='http://schemas.android.com/tools' xmlns:lh2='http://schemas.android.com/apk/res/com.ctgu.circleprogressbar' android:layout_width='match_parent' android:layout_height='match_parent' > <com.ctgu.circleprogressbar.CircleProgressBar android: android:layout_width='150dp' android:layout_height='150dp' android:layout_centerHorizontal='true' android:layout_gravity='center' android:layout_marginTop='20dp' lh2:circleWidth='6dp' lh2:firstColor='#d3d3d3' lh2:secondColor='#3B95C8' /> <SeekBar android: android:layout_width='match_parent' android:layout_height='wrap_content' android:layout_alignParentBottom='true' android:layout_marginBottom='40dp' android:layout_marginLeft='10dp' android:layout_marginRight='10dp' android:background='#778899' /> </RelativeLayout>

4、MainActivity.java

package com.ctgu.circleprogressbar; import android.app.Activity;import android.graphics.Color;import android.os.Bundle;import android.os.Handler;import android.widget.SeekBar; public class MainActivity extends Activity{ private CircleProgressBar circleProgressBar; // 自定義的進度條 private SeekBar seekbar; // 拖動條 private int[] colors = new int[] { Color.parseColor('#27B197'), Color.parseColor('#00A6D5') }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); circleProgressBar = (CircleProgressBar) findViewById(R.id.circleProgressBar);// circleProgressBar.setFirstColor(Color.LTGRAY);// circleProgressBar.setColorArray(colors); //覺得進度條顏色丑的,這里可以自行傳入一個顏色漸變數組。// circleProgressBar.setCircleWidth(6); seekbar = (SeekBar) findViewById(R.id.seekbar); seekbar.setMax(100); seekbar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { @Override public void onStopTrackingTouch(SeekBar seekBar) { } @Override public void onStartTrackingTouch(SeekBar seekBar) { } @Override public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) { if (fromUser) { // circleProgressBar.setProgress(progress); //不使用動畫 circleProgressBar.setProgress(progress, true); // 使用數字過渡動畫 } } }); }}

代碼注釋很詳細了,基本上了解自定義控件的都看得懂。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Android
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国内精品福利| 欧美日韩在线观看首页| 性色一区二区| 欧美成人久久| 精品一区毛片| 日韩高清中文字幕一区| 久久国产亚洲| 欧美丝袜一区| 91精品久久久久久久久久不卡| 高清一区二区三区av| 国产专区精品| 在线看片福利| av资源中文在线| 日韩国产专区| 激情视频一区二区三区| 蜜臀av免费一区二区三区| 久久一区二区三区电影| 精品一区亚洲| 久久亚洲图片| 日韩一区免费| 国产精品一区高清| 国产精品欧美三级在线观看| 国产精品成人3p一区二区三区| 久久av电影| 在线天堂中文资源最新版| 亚洲播播91| 国精品一区二区| 视频一区国产视频| 日韩av中文字幕一区二区| 久久精品xxxxx| 国产成人精品一区二区三区视频| 国产aⅴ精品一区二区三区久久| 久久精品影视| 免费日韩av片| 欧美午夜三级| 日韩88av| 久久人人99| 日韩欧美高清一区二区三区| 国产经典一区| 激情婷婷亚洲| 欧美日韩99| 日韩免费小视频| 亚洲三级国产| 黄毛片在线观看| 免费人成精品欧美精品| 免费看一区二区三区| 久久精品亚洲人成影院| 亚洲精品进入| 免费看av不卡| 日韩精品久久久久久久软件91| 国精品产品一区| 亚洲精品小说| 国产精品天堂蜜av在线播放| 国产 日韩 欧美 综合 一区| 五月天久久网站| 日本欧美在线看| 精品色999| 欧美美女一区| 欧美一区二区三区久久精品| 国产一区精品福利| 欧美日韩视频一区二区三区| 99精品在线| 久久久久国产| 四虎精品永久免费| 国产成人精品一区二区三区视频| 一区二区小说| 日韩中文字幕一区二区三区| 日本中文字幕一区二区| 免费亚洲婷婷| 久久蜜桃av| 午夜天堂精品久久久久| 欧美国产先锋| 在线视频观看日韩| 亚洲激情另类| 国产日本亚洲| 久久久久久久久丰满| 亚洲a级精品| 美女视频黄 久久| 九九综合九九| 国产精品一区2区3区| 亚洲成人av观看| 蜜臀精品久久久久久蜜臀| 免费亚洲一区| 国产农村妇女精品一二区| 国产精品jk白丝蜜臀av小说| 深夜视频一区二区| 日韩手机在线| 欧美羞羞视频| 啪啪亚洲精品| av最新在线| 国产麻豆精品| 99国产精品久久久久久久| 国产精品1区| 亚洲一区二区三区免费在线观看| 国产精品麻豆成人av电影艾秋| 欧美va天堂在线| 欧美久久亚洲| 激情综合网五月| 精品美女视频| 日韩一区二区三区在线看| 深夜视频一区二区| 国产欧美高清视频在线| 亚洲免费黄色| 国产自产自拍视频在线观看| 日韩高清一级| 亚洲高清影视| 日韩激情中文字幕| 亚洲香蕉久久| 一区二区小说| 精品国产亚洲一区二区三区在线| 日韩精品一二三四| 日韩美女一区二区三区在线观看| 日本中文字幕不卡| 九九在线精品| 午夜影院一区| 国产精品黄色片| 亚洲三级网址| 蜜桃视频免费观看一区| 久久精品青草| 精品一区二区三区免费看| 亚洲精品极品| 在线视频免费在线观看一区二区| av综合电影网站| 国产精品极品在线观看| 日韩中文字幕91| 99久久精品费精品国产| 久久久精品区| 日韩精品导航| 日韩高清在线不卡| 免费在线看一区| 欧美在线亚洲| 日韩三区免费| 成人午夜在线| 国产精品主播| 日本视频一区二区| 亚洲精品系列| 亚洲视频电影在线| 亚洲国产专区校园欧美| 国产综合婷婷| 成人羞羞在线观看网站| 久久亚洲资源中文字| 日本午夜精品| 亚州av日韩av| 亚洲不卡视频| 亚洲欧洲av| 亚洲精品美女91| 中文字幕日本一区二区| 2023国产精品久久久精品双 | 欧美在线黄色| 亚洲久久视频| 午夜影院欧美| 欧美日韩视频| 国产精品婷婷| 男女男精品视频网| 在线国产精品一区| 一区视频在线| 在线亚洲激情| 亚洲欧美日韩视频二区| 国产精品日韩久久久| 亚洲欧美高清| 午夜在线一区二区| 欧美一级一区| 国产精品对白| 精品国产一级| 亚洲成人不卡| 亚洲欧洲日本mm| 日本大胆欧美人术艺术动态| 首页国产欧美日韩丝袜| 免费人成在线不卡| 亚洲精品影院在线观看| 免费久久精品视频| 日韩精品一区二区三区中文| 久久国产三级| 精品视频免费| 亚洲高清激情| 日本亚洲视频| 久久精品97| 精品深夜福利视频| 欧产日产国产精品视频| 欧美在线影院| 日本不卡视频在线观看| 久久99精品久久久野外观看| 在线看片国产福利你懂的| 91亚洲国产高清| 美女91精品| 日韩精品免费视频一区二区三区| 欧美日本精品| 国产传媒av在线| 91九色精品国产一区二区| 视频一区视频二区中文| 欧美亚洲专区| 国产不卡人人| 女同性一区二区三区人了人一| 久久激情综合网| 日韩精品第一区| 伊人国产精品| 久久一区视频| 亚洲精品网址| 欧美私人啪啪vps| 日韩欧美字幕|