效果圖:

A.繪制圓環(huán),圓弧,文本
//1.畫(huà)圓環(huán)//原點(diǎn)坐標(biāo)float circleX = width / 2;float circleY = width / 2;//半徑float radius = width / 2 - roundWidth / 2;//設(shè)置畫(huà)筆的屬性paint.setColor(roundColor);paint.setStrokeWidth(roundWidth);paint.setStyle(Paint.Style.STROKE);canvas.drawCircle(circleX, circleY, radius, paint);//2.畫(huà)圓弧RectF oval = new RectF(roundWidth/2,roundWidth/2,width-roundWidth/2,width - roundWidth/2);paint.setColor(roundProgressColor);canvas.drawArc(oval, 0, progress * 360 / max, false, paint);//3.畫(huà)文本paint.setTextSize(textSize);paint.setColor(textColor);paint.setStrokeWidth(0);String text = progress * 100 / max + "%";Rect bounds = new Rect();paint.getTextBounds(text, 0, text.length(), bounds);canvas.drawText(text, width / 2 - bounds.width() / 2, width / 2 + bounds.height() / 2, paint);
B.自定義屬性的具體步驟
具體步驟:
1. 定義屬性: 在values目錄下創(chuàng)建attrs.xml
<declare-styleable name="RoundProgress"> <attr name="roundColor" format="color"></attr> <attr name="roundProgressColor" format="color"></attr> <attr name="textColor" format="color"></attr> <attr name="roundWidth" format="dimension"></attr> <attr name="textSize" format="dimension"></attr></declare-styleable>
2. 在布局文件中引用當(dāng)前應(yīng)用的名稱(chēng)空間
xmlns:atguigu=http://schemas.android.com/apk/res-auto
3. 在自定義視圖標(biāo)簽中使用自定義屬性
<com.atguigu.p2p.util.RoundProgress android/168359.html">android:id="@+id/rp_home_progress" android:layout_width="120dp" android:layout_height="120dp" android:layout_gravity="center_horizontal" android:layout_marginTop="20dp" atguigu:roundColor="@android:color/darker_gray <br> atguigu:roundProgressColor="@android:color/holo_red_dark" atguigu:textColor="@color/text_progress" atguigu:roundWidth="10dp" atguigu:textSize="20sp" />
4. 在自定義View類(lèi)的構(gòu)造方法中, 取出布局中的自定義屬性值
//1.得到所有自定義屬性的數(shù)組TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.RoundProgress);//2.獲取自定義屬性的值, 如果沒(méi)有指定取默認(rèn)值roundColor = typedArray.getColor(R.styleable.RoundProgress_roundColor, Color.RED);roundProgressColor = typedArray.getColor(R.styleable.RoundProgress_roundProgressColor, Color.GREEN);textColor = typedArray.getColor(R.styleable.RoundProgress_textColor, Color.GREEN);roundWidth = typedArray.getDimension(R.styleable.RoundProgress_roundWidth, UIUtils.dp2px(10));textSize = typedArray.getDimension(R.styleable.RoundProgress_textSize, UIUtils.dp2px(20));//3.釋放資源數(shù)據(jù)typedArray.recycle();
C.讓圓環(huán)進(jìn)度"動(dòng)起來(lái)"
1.自定義RoundProgress類(lèi)中提供進(jìn)度屬性的getter和setter方法
2.在HomeFragment的onSuccess()中:
github:https://github.com/ganchuanpu/P2PInvest
以上所述是小編給大家介紹的Android動(dòng)態(tài)自定義圓形進(jìn)度條,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)VEVB武林網(wǎng)網(wǎng)站的支持!
|
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注