【Android工具类】验证码倒计时帮助类CountDownButtonHelper的实现

时间:2021-08-21 23:24:56
转载请注明出处: http://blog.csdn.net/zhaokaiqiang1992

    我们在做有关短信验证码功能的时候,为了防止用户无休止的获取短信验证码,或者是误操作,造成验证码混乱的情况,我们一般在获取验证码功能的Button上面加上倒计时功能,从而限制用户获取验证码的间隔。

    今天这篇文章,是介绍如何使用CountDowmTimer实现验证码的倒计时功能的。

    先看效果图

【Android工具类】验证码倒计时帮助类CountDownButtonHelper的实现

    CountDownTimer是一个系统提供的一个关于倒计数的类,我们可以设置倒计时的总时间,还有倒计时的间隔,这样每过一段固定时间,我们就可以在回调函数中进行我们的操作。下面是CountDownTimer类的回调方法和构造函数。

    CountDownTimer timer = new CountDownTimer(AllTime,Intevel) {    

@Override
public void onTick(long millisUntilFinished) {

}

@Override
public void onFinish() {

}
};

  new CountDownTimer(AllTime,Intevel)

    第一个参数是总时间,第二个是倒计时间隔。

    onTick()是倒计时到了间隔时间之后的回调函数。

    onFinish()是计时结束之后调用的函数。

    下面,给出我的倒计时帮助类。

    package com.example.countdowntimerdemo;  

import android.os.CountDownTimer;
import android.util.Log;
import android.widget.Button;

/**
* 倒计时Button帮助类
*
* @author zhaokaiqiang
* @see http://blog.csdn.net/zhaokaiqiang1992
*/
public class CountDownButtonHelper {

// 倒计时timer
private CountDownTimer countDownTimer;
// 计时结束的回调接口
private OnFinishListener listener;

private Button button;

/**
*
* @param button
* 需要显示倒计时的Button
* @param defaultString
* 默认显示的字符串
* @param max
* 需要进行倒计时的最大值,单位是秒
* @param interval
* 倒计时的间隔,单位是秒
*/
public CountDownButtonHelper(final Button button,
final String defaultString, int max, int interval) {

this.button = button;
// 由于CountDownTimer并不是准确计时,在onTick方法调用的时候,time会有1-10ms左右的误差,这会导致最后一秒不会调用onTick()
// 因此,设置间隔的时候,默认减去了10ms,从而减去误差。
// 经过以上的微调,最后一秒的显示时间会由于10ms延迟的积累,导致显示时间比1s长max*10ms的时间,其他时间的显示正常,总时间正常
countDownTimer = new CountDownTimer(max * 1000, interval * 1000 - 10) {

@Override
public void onTick(long time) {
// 第一次调用会有1-10ms的误差,因此需要+15ms,防止第一个数不显示,第二个数显示2s
button.setText(defaultString + "(" + ((time + 15) / 1000)
+ "秒)");
Log.d("CountDownButtonHelper", "time = " + (time) + " text = "
+ ((time + 15) / 1000));
}

@Override
public void onFinish() {
button.setEnabled(true);
button.setText(defaultString);
if (listener != null) {
listener.finish();
}
}
};
}

/**
* 开始倒计时
*/
public void start() {
button.setEnabled(false);
countDownTimer.start();
}

/**
* 设置倒计时结束的监听器
*
* @param listener
*/
public void setOnFinishListener(OnFinishListener listener) {
this.listener = listener;
}

/**
* 计时结束的回调接口
*
* @author zhaokaiqiang
*
*/
public interface OnFinishListener {
public void finish();
}

}

  测试源代码下载地址,请关注我的github https://github.com/ZhaoKaiQiang/CountDownTimerDemo