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

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

在商丘等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都网站制作、做网站、外贸营销网站建设 网站设计制作按需定制网站,公司网站建设,企业网站建设,品牌网站设计,营销型网站,成都外贸网站制作,商丘网站建设费用合理。

代码块

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

                   

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如何自定义圆形倒计时显示控件”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


新闻标题:android如何自定义圆形倒计时显示控件
本文来源:http://pwwzsj.com/article/pispcs.html