当前位置: 移动技术网 > 移动技术>移动开发>Android > Android实现发送短信验证码倒计时功能示例

Android实现发送短信验证码倒计时功能示例

2019年07月24日  | 移动技术网移动技术  | 我要评论

一、简介:

开发中在用户注册或找回密码之类的功能,经常会遇到获取短信验证码,获取验证码后需要等待1分钟倒计时,这段时间是不能再次发送短信请求的。

效果图:


二、实现步骤:

1、一个关键类:countdowntimer(android系统自带的倒计时功能类)

public class countdowntimerutils extends countdowntimer {

  private textview mtextview; //显示倒计时的文字

  /**
   * @param textview     the textview
   * @param millisinfuture   millisinfuture 从开始调用start()到倒计时完成
   *              并onfinish()方法被调用的毫秒数。(译者注:倒计时时间,单位毫秒)
   * @param countdowninterval 接收ontick(long)回调的间隔时间。(译者注:单位毫秒)
   */
  public countdowntimerutils(textview textview, long millisinfuture, long countdowninterval) {
    super(millisinfuture, countdowninterval);
    this.mtextview = textview;
  }

  @override
  public void ontick(long millisuntilfinished) {
    mtextview.setclickable(false); //设置不可点击
    mtextview.settext(millisuntilfinished / 1000 + "秒后可重新发送"); //设置倒计时时间
    mtextview.setbackgroundresource(r.drawable.validate_code_press_bg); //设置按钮为灰色,这时是不能点击的

    /**
     * 超链接 urlspan
     * 文字背景颜色 backgroundcolorspan
     * 文字颜色 foregroundcolorspan
     * 字体大小 absolutesizespan
     * 粗体、斜体 stylespan
     * 删除线 strikethroughspan
     * 下划线 underlinespan
     * 图片 imagespan
     */
    spannablestring spannablestring = new spannablestring(mtextview.gettext().tostring()); //获取按钮上的文字
    foregroundcolorspan span = new foregroundcolorspan(color.red);
    /**
     * public void setspan(object what, int start, int end, int flags) {
     * 主要是start跟end,start是起始位置,无论中英文,都算一个。
     * 从0开始计算起。end是结束位置,所以处理的文字,包含开始位置,但不包含结束位置。
     */
    spannablestring.setspan(span, 0, 2, spannable.span_inclusive_exclusive);//将倒计时的时间设置为红色
    mtextview.settext(spannablestring);
  }

  @override
  public void onfinish() {
    mtextview.settext("重新获取验证码");
    mtextview.setclickable(true);//重新获得点击
    mtextview.setbackgroundresource(r.drawable.validate_code_normal_bg); //还原背景色
  }
}

2、在合适的地方调用

使用:

countdowntimerutils mcountdowntimerutils = new countdowntimerutils(mbutton, 60000, 1000); //倒计时1分钟
mcountdowntimerutils.start();

3、validate_code_press_bg.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
  <!--发送短信验证码按钮被按下-->
  <solid android:color="#c0c0c0" /> <!--填充色 透明-->
  <corners android:radius="8dp" /> <!-- 圆角 -->
</shape>

validate_code_normal_bg.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
  <!--发送短信验证码按钮未按下-->
  <solid android:color="#ff9933" /> <!--填充色 透明-->
  <corners android:radius="8dp" /> <!-- 圆角 -->
</shape>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网