麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 系統 > Android > 正文

Android自定義帶圓點的半圓形進度條

2019-10-21 21:31:20
字體:
來源:轉載
供稿:網友

本文實例為大家分享了Android自定義帶圓點的半圓形進度條,供大家參考,具體內容如下

僅限用于半圓形,如須要帶圓點的圓形進度條,圓點會出現錯位現象,此代碼僅供,帶圓點的圓形進度條有空研究一下!圖片效果在下方,

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.view.View;/** * 自定義帶圓點的進度條 */public class HalfProgressBar extends View{ private int maxProgress = 100; //設置進度條背景寬度 private float progressStrokeWidth = 3; //設置進度條進度寬度 private float marxArcStorkeWidth = 6; //設置進度條圓點的寬度 private float circularDotWidth=15; /**  * 畫筆對象的引用  */ private Paint paint; public synchronized int getProgress() {  return progress; } /**  * Android提供了Invalidate方法實現界面刷新,但是Invalidate不能直接在線程中調用,因為他是違背了單線程模型:Android UI操作并不是線程安全的,并且這些操作必須在UI線程中調用。  * 而postInvalidate()在工作者線程中被調用 使用postInvalidate則比較簡單,不需要handler,直接在線程中調用postInvalidate即可。   * @param progress 傳過來的進度  */ public void setProgress(int progress) {  if (progress < 0) {   progress = 0;  }  if (progress > maxProgress) {   progress = maxProgress;  }  if (progress <= maxProgress) {   this.progress = progress;   postInvalidate();  } } /**  * 當前進度  */ private int progress = 99; private RectF oval; private int roundProgressColor; private int roundColor; private int circularDotColor; public HalfProgressBar(Context context) {  super(context); } public HalfProgressBar(Context context, AttributeSet attrs) {  super(context, attrs);  paint = new Paint();  oval = new RectF();  //這是自定義view 必須要寫的  TypedArray mTypedArray = context.obtainStyledAttributes(attrs, R.styleable.HalfProgressBar);  roundProgressColor = mTypedArray.getColor(R.styleable.HalfProgressBar_roundProgressColor1, Color.YELLOW);  roundColor=mTypedArray.getColor(R.styleable.HalfProgressBar_roundColor1, Color.YELLOW);  circularDotColor=mTypedArray.getColor(R.styleable.HalfProgressBar_circularDotColor1, Color.YELLOW); } public HalfProgressBar(Context context, AttributeSet attrs, int defStyleAttr) {  super(context, attrs, defStyleAttr);  paint = new Paint();  oval = new RectF();  TypedArray mTypedArray = context.obtainStyledAttributes(attrs, R.styleable.HalfProgressBar);  roundProgressColor = mTypedArray.getColor(R.styleable.HalfProgressBar_roundProgressColor1, Color.YELLOW);  roundColor=mTypedArray.getColor(R.styleable.HalfProgressBar_roundColor1, Color.YELLOW); } @Override protected void onDraw(Canvas canvas) {  // TODO 自動生成的方法存根  super.onDraw(canvas);  float width = getWidth();  float height = getHeight();  paint.setAntiAlias(false); // 設置畫筆為抗鋸齒  paint.setColor(roundColor); // 設置畫筆顏色  paint.setStrokeWidth(progressStrokeWidth); // 線寬  paint.setStyle(Paint.Style.STROKE);  oval.left = marxArcStorkeWidth / 2; // 左上角x  oval.top = circularDotWidth; // 左上角y  oval.right = width - circularDotWidth / 2; // 左下角x  oval.bottom = width - circularDotWidth / 2; // 右下角y  float bangjing = ((width - circularDotWidth/2) / 2);//半徑  //調整圓背景的大小  canvas.drawArc(oval, 180, 180, false, paint); // 繪制紅絲圓圈,即進度條背景  //進度條顏色  paint.setColor(roundProgressColor);  paint.setStrokeWidth(marxArcStorkeWidth);  canvas.drawArc(oval, 180, 180 * ((float) progress / (float) maxProgress), false, paint); // 繪制進度圓弧,這里是藍色  //畫圓點  paint.setColor(circularDotColor);  paint.setAntiAlias(true); // 設置畫筆為抗鋸齒  paint.setStyle(Paint.Style.FILL);  paint.setStrokeWidth(circularDotWidth);  //當畫筆樣式為STROKE或FILL_OR_STROKE時,設置筆刷的圖形樣式,如圓形樣式Cap.ROUND,或方形樣式Cap.SQUARE  paint.setStrokeCap(Paint.Cap.ROUND);  float jindu = ((float) progress * 1.8f);  canvas.drawPoint(bangjing - ((float) (Math.sin((Math.PI / (double) 180) * (jindu <= 90 ? 90 - (jindu) : -jindu + 90))) * bangjing),   bangjing+circularDotWidth - ((float) (Math.cos((Math.PI / (double) 180) * (double) (jindu <= 90 ? 90 - jindu : -jindu + 90))) * bangjing), paint); }}

attrs.xml

<?xml version="1.0" encoding="utf-8"?><resources> <!--自定義半圓形加載進度條--> <declare-styleable name="HalfProgressBar">  <attr name="roundColor1" format="color"/>  <attr name="roundProgressColor1" format="color"/>  <attr name="circularDotColor1" format="color"/> </declare-styleable></resources>

xml中

<com.jyc99.demo.HalfProgressBar  android:layout_width="match_parent"  android:layout_height="wrap_content"  android:id="@+id/view"  android:layout_centerHorizontal="true"  android:layout_marginTop="42dp"  android_custom:roundColor1="#fc422b"  android_custom:roundProgressColor1="#fa432e"  android_custom:circularDotColor1="#246223"/>

由于截圖的原因可能看不到圓點 , 大家自己試試調調顏色 調整一下高度寬度 

Android,圓點,半圓形,進度條

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


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美在线观看黄色 | 91av大片| 色av成人天堂桃色av | 在线观看免费视频麻豆 | 亚洲码无人客一区二区三区 | 一区二区久久电影 | 8x成人在线电影 | 中文字幕在线播放视频 | 国产日本在线播放 | 成人三级电影网址 | 黄色a级片视频 | 亚洲成人久久精品 | 青青草免费观看 | 精品国产一区二区久久 | 国产在线观看 | 好吊色37pao在线观看 | 久久精片 | 国产一区国产二区在线观看 | 亚洲国产成人久久一区www妖精 | 国产精品一区二区三区在线看 | av噜噜在线 | 欧美一区二区三区中文字幕 | 欧美wwwwww | 蜜桃视频在线免费播放 | 真人一级毛片免费 | 一级国产免费 | 91婷婷射 | 一本一本久久a久久精品综合小说 | 91成人影库 | 久久无毛 | 免费国产成人高清在线看软件 | 成人在线视频精品 | 沉沦的校花奴性郑依婷c到失禁 | 在线观看一区二区三区四区 | 日本一道aⅴ不卡免费播放 视屏一区 | 精品一区二区三区日本 | 黄色视频a级毛片 | v11av在线播放 | 蜜桃网站在线 | 天天色综合6 | 国产成年人网站 |