android實現(xiàn)簡單儀表盤效果
本文實例為大家分享了android實現(xiàn)簡單儀表盤效果的具體代碼,供大家參考,具體內容如下
實現(xiàn)這個效果:
中間的文字很好寫,外層的進度條就需要自定義控件了,代碼如下:
public class CirCleProgressBar extends View { private Paint circlePaint; private Paint textPaint; private int circleColor;//圓弧顏色 private int circleBgColor;//圓弧背景顏色 private float circleWidth;//圓弧寬度 private float circleBgWidth;//圓弧背景寬度 private int textColor;//字體顏色 private float textSize;//字體大小 private int totalAngle;//總角度 private int startAngle;//開始角度 private float currentProgress;//當前進度 private float maxProgress;//最大進度 private float section;//分段 private float currentAngle;//當前角度 private float lastAngle; private ValueAnimator progressAnimator;//圓弧動畫 private int duration = 1000;//動畫時長 private boolean isDefaultText;//是否設置文字顯示的值 private String mTextValue;//字體顯示的值 public CirCleProgressBar(Context context) { this(context, null); } public CirCleProgressBar(Context context, AttributeSet attrs) { this(context, attrs, 0); } public CirCleProgressBar(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); circlePaint = new Paint(); textPaint = new Paint(); TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.CirCleProgressBar); circleColor = typedArray.getColor(R.styleable.CirCleProgressBar_circle_color, Color.RED); circleBgColor = typedArray.getColor(R.styleable.CirCleProgressBar_circle_bg_color, Color.YELLOW); circleWidth = typedArray.getDimension(R.styleable.CirCleProgressBar_circle_width, 2); circleBgWidth = typedArray.getDimension(R.styleable.CirCleProgressBar_circle_bg_width, 2); textColor = typedArray.getColor(R.styleable.CirCleProgressBar_text_color, Color.BLUE); textSize = typedArray.getDimension(R.styleable.CirCleProgressBar_text_size, 10); totalAngle = typedArray.getInteger(R.styleable.CirCleProgressBar_total_angle, 360); startAngle = typedArray.getInteger(R.styleable.CirCleProgressBar_start_angle, 0); currentProgress = typedArray.getFloat(R.styleable.CirCleProgressBar_current_progress, 0); maxProgress = typedArray.getFloat(R.styleable.CirCleProgressBar_max_progress, 100); setCurrentProgress(currentProgress); setMaxProgress(maxProgress); // typedArray.recycle(); } @SuppressLint("DrawAllocation") @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); /** * 畫最外層的大圓環(huán) */ int centre = getWidth() / 2; // 獲取圓心的x坐標 int radius = (int) (centre - circleWidth / 2) - 2; // 圓環(huán)的半徑 circlePaint.setColor(circleBgColor); circlePaint.setStyle(Paint.Style.STROKE); circlePaint.setAntiAlias(true); circlePaint.setStrokeCap(Paint.Cap.ROUND);// 圓頭 circlePaint.setStrokeWidth(circleBgWidth); RectF oval = new RectF(centre - radius - 1, centre - radius - 1, centre + radius + 1, centre + radius + 1); // 用于定義的圓弧的形狀和大小的界限 //背景圓 canvas.drawArc(oval, startAngle, totalAngle, false, circlePaint); //數(shù)據(jù)圓 circlePaint.setStrokeWidth(circleWidth); circlePaint.setColor(circleColor); canvas.drawArc(oval, startAngle, currentAngle, false, circlePaint); // textPaint.setAntiAlias(true); textPaint.setColor(textColor); textPaint.setTextSize(textSize); float textWidth = textPaint.measureText((int) currentProgress + ""); if(!isDefaultText) { canvas.drawText(String.valueOf((int)currentProgress), centre - textWidth / 2, centre + textSize / 2, textPaint); }else { canvas.drawText(mTextValue, centre - textWidth / 2, centre + textSize / 2, textPaint); } // invalidate(); } public float getMaxProgress(){ return maxProgress; } public void setMaxProgress(float maxProgress){ if(maxProgress < 0){ throw new IllegalArgumentException("max not less than 0"); } this.maxProgress = maxProgress; section = totalAngle / maxProgress; } public void setAnimationDuration(int duration){ this.duration = duration; } public void setCurrentProgress(float progress){ if(progress >= 0){ this.currentProgress = progress; if(progress > maxProgress){ progress = maxProgress; } lastAngle = currentAngle; setAnimation(lastAngle, progress * section, duration); } } private void setAnimation(float last, float current, int duration){ progressAnimator = ValueAnimator.ofFloat(last, current); progressAnimator.setDuration(duration); progressAnimator.setTarget(currentAngle); progressAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator valueAnimator) { currentAngle = (float) valueAnimator.getAnimatedValue(); currentProgress = currentAngle / section; } }); progressAnimator.start(); } public int getCircleColor() { return circleColor; } public void setCircleColor(int circleColor) { this.circleColor = circleColor; } public int getCircleBgColor() { return circleBgColor; } public void setCircleBgColor(int circleBgColor) { this.circleBgColor = circleBgColor; } public float getCircleWidth() { return circleWidth; } public void setCircleWidth(float circleWidth) { this.circleWidth = circleWidth; } public float getCircleBgWidth() { return circleBgWidth; } public void setCircleBgWidth(float circleBgWidth) { this.circleBgWidth = circleBgWidth; } public int getTextColor() { return textColor; } public void setTextColor(int textColor) { this.textColor = textColor; } public float getTextSize() { return textSize; } public void setTextSize(float textSize) { this.textSize = textSize; } /** * @param isText 為true,自定義設置字體顯示 * @param text */ public void setText(boolean isText,String text){ isDefaultText = isText; mTextValue = text; } }
需要在attrs中添加:
<declare-styleable name="CirCleProgressBar"> <attr name="circle_color" format="color"/> <attr name="circle_bg_color" format="color"/> <attr name="circle_width" format="dimension"/> <attr name="circle_bg_width" format="dimension"/> <attr name="text_color" format="color"/> <attr name="text_size" format="dimension"/> <attr name="total_angle" format="integer"/> <attr name="start_angle" format="integer"/> <attr name="current_progress" format="float"/> <attr name="max_progress" format="float"/> </declare-styleable>
使用方法:
在布局文件中直接引用
<com.fm.newcinema.view.CirCleProgressBar android:id="@+id/cc_cinema_sentiment" android:layout_width="139dp" android:layout_height="99dp" android:layout_gravity="center_horizontal" android:layout_marginTop="8dp" app:circle_bg_color="@color/gray_line_ff" app:circle_bg_width="10dp" app:circle_color="@color/main_blue" app:circle_width="10dp" app:max_progress="100" app:start_angle="160" app:text_color="@color/white_ff" app:text_size="@dimen/size_30px" app:total_angle="221"/>
其中app:circle_bg_color表示進度條底層的顏色,app:circle_color表示進度條上層的顏色,app:circle_bg_width表示進度條底層的寬度,app:circle_width表示進度條上層的寬度,app:max_progress="100"表示進度條最大進度是100,app:start_angle表示開始的角度,就是進度條從哪個角度開始畫,如下圖所示
app:total_angle表示整個進度條所需的角度.
在代碼中設置旋轉的角度,圖中進度為30%,由于在布局文件中設置的最大進度是100`app:max_progress="100",所以進行如下設置peocess.setCurrentProgress(30f)
默認情況下,進度條中間顯示進度條的值,如果需要自己寫值的畫,調用這個方法:process.setText(true, "中間的字");
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Android 網(wǎng)絡請求框架Volley實例詳解
這篇文章主要介紹了Android 網(wǎng)絡請求框架Volley實例詳解的相關資料,需要的朋友可以參考下2017-06-06Android開發(fā)數(shù)據(jù)結構算法ArrayList源碼詳解
這篇文章主要為大家介紹了Android開發(fā)數(shù)據(jù)結構算法ArrayList源碼詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10Android短信驗證碼監(jiān)聽解決onChange多次調用的方法
本篇文章主要介紹了Android短信驗證碼監(jiān)聽解決onChange多次調用的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-03-03Android框架Volley使用:ImageRequest請求實現(xiàn)圖片加載
這篇文章主要介紹了Android框架Volley使用:ImageRequest請求實現(xiàn)圖片加載的相關知識,非常不錯,具有一定的參考借鑒價值 ,需要的朋友可以參考下2019-05-05Android獲取手機屏幕寬高、狀態(tài)欄高度以及字符串寬高信息的方法
這篇文章主要介紹了Android獲取手機屏幕寬高、狀態(tài)欄高度以及字符串寬高信息的方法,涉及Android獲取文字寬高、狀態(tài)欄高度、textView寬度及屏幕尺寸的相關技巧,需要的朋友可以參考下2015-04-04Android實現(xiàn)底部圖標與Fragment的聯(lián)動實例
本篇文章主要介紹了Android實現(xiàn)底部圖標與Fragment的聯(lián)動實例,具有一定的參考價值,有興趣的可以了解一下2017-07-07