温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

android如何自定义圆形倒计时显示控件

发布时间:2021-09-27 13:47:14 来源:亿速云 阅读:130 作者:小新 栏目:编程语言

这篇文章主要为大家展示了“android如何自定义圆形倒计时显示控件”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“android如何自定义圆形倒计时显示控件”这篇文章吧。

代码块

attr.xml 控件需要用到的属性:

<?xml version="1.0" encoding="utf-8"?><resources> <declare-styleable name="CountDownView">  <!--颜色-->  <attr name="ringColor" format="color" />  <!-- 进度文本的字体大小 -->  <attr name="progressTextSize" format="dimension" />  <!-- 圆环宽度 -->  <attr name="ringWidth" format="float" />  <!--进度文本颜色-->  <attr name="progressTextColor" format="color"/>  <!--倒计时-->  <attr name="countdownTime" format="integer"/> </declare-styleable></resources>

CountDownView.java

public class CountDownView extends View { //圆轮颜色 private int mRingColor; //圆轮宽度 private float mRingWidth; //圆轮进度值文本大小 private int mRingProgessTextSize; //宽度 private int mWidth; //高度 private int mHeight; private Paint mPaint; //圆环的矩形区域 private RectF mRectF; // private int mProgessTextColor; private int mCountdownTime; private float mCurrentProgress; private OnCountDownFinishListener mListener; public CountDownView(Context context) {  this(context, null); } public CountDownView(Context context, AttributeSet attrs) {  this(context, attrs, 0); } public CountDownView(Context context, AttributeSet attrs, int defStyleAttr) {  super(context, attrs, defStyleAttr);  TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.CountDownView);  mRingColor = a.getColor(R.styleable.CountDownView_ringColor, context.getResources().getColor(R.color.colorAccent));  mRingWidth = a.getFloat(R.styleable.CountDownView_ringWidth, 40);  mRingProgessTextSize = a.getDimensionPixelSize(R.styleable.CountDownView_progressTextSize, DisplayUtils.sp2px(context, 20));  mProgessTextColor = a.getColor(R.styleable.CountDownView_progressTextColor, context.getResources().getColor(R.color.colorAccent));  mCountdownTime = a.getInteger(R.styleable.CountDownView_countdownTime, 60);  a.recycle();  mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);  mPaint.setAntiAlias(true);  this.setWillNotDraw(false); } public void setCountdownTime(int mCountdownTime) {  this.mCountdownTime = mCountdownTime; } @Override protected void onLayout(boolean changed, int left, int top, int right, int bottom) {  super.onLayout(changed, left, top, right, bottom);  mWidth = getMeasuredWidth();  mHeight = getMeasuredHeight();  mRectF = new RectF(0 + mRingWidth / 2, 0 + mRingWidth / 2,    mWidth - mRingWidth / 2, mHeight - mRingWidth / 2); } @Override protected void onDraw(Canvas canvas) {  super.onDraw(canvas);  /**   *圆环   */  //颜色  mPaint.setColor(mRingColor);  //空心  mPaint.setStyle(Paint.Style.STROKE);  //宽度  mPaint.setStrokeWidth(mRingWidth);  canvas.drawArc(mRectF, -90, mCurrentProgress - 360, false, mPaint);  //绘制文本  Paint textPaint = new Paint();  textPaint.setAntiAlias(true);  textPaint.setTextAlign(Paint.Align.CENTER);  String text = mCountdownTime - (int) (mCurrentProgress / 360f * mCountdownTime) + "";  textPaint.setTextSize(mRingProgessTextSize);  textPaint.setColor(mProgessTextColor);  //文字居中显示  Paint.FontMetricsInt fontMetrics = textPaint.getFontMetricsInt();  int baseline = (int) ((mRectF.bottom + mRectF.top - fontMetrics.bottom - fontMetrics.top) / 2);  canvas.drawText(text, mRectF.centerX(), baseline, textPaint); } private ValueAnimator getValA(long countdownTime) {  ValueAnimator valueAnimator = ValueAnimator.ofFloat(0, 100);  valueAnimator.setDuration(countdownTime);  valueAnimator.setInterpolator(new LinearInterpolator());  valueAnimator.setRepeatCount(0);  return valueAnimator; } /**  * 开始倒计时  */ public void startCountDown() {  setClickable(false);  ValueAnimator valueAnimator = getValA(mCountdownTime * 1000);  valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {   @Override   public void onAnimationUpdate(ValueAnimator animation) {    float i = Float.valueOf(String.valueOf(animation.getAnimatedValue()));    mCurrentProgress = (int) (360 * (i / 100f));    invalidate();   }  });  valueAnimator.start();  valueAnimator.addListener(new AnimatorListenerAdapter() {   @Override   public void onAnimationEnd(Animator animation) {    super.onAnimationEnd(animation);    //倒计时结束回调    if (mListener != null) {     mListener.countDownFinished();    }    setClickable(true);   }  }); } public void setAddCountDownListener(OnCountDownFinishListener mListener) {  this.mListener = mListener; } public interface OnCountDownFinishListener {  void countDownFinished(); }}

MainActivity.java

package com.ouyuan.demo.myapplication;import android.animation.ValueAnimator;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.view.View;import android.widget.TextView;import android.widget.Toast;public class MainActivity extends AppCompatActivity { CountDownView cdv; TextView textView; @Override protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.activity_main);  cdv = (CountDownView) findViewById(R.id.countDownView);  cdv.setAddCountDownListener(new CountDownView.OnCountDownFinishListener() {   @Override   public void countDownFinished() {    Toast.makeText(MainActivity.this, "倒计时结束", Toast.LENGTH_SHORT).show();   }  });  cdv.setOnClickListener(new View.OnClickListener() {   @Override   public void onClick(View v) {    cdv.startCountDown();   }  }); }}

以上是“android如何自定义圆形倒计时显示控件”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI