欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android开发之获取短信验证码后按钮背景变化并且出现倒计时

程序员文章站 2024-02-12 13:00:58
目前越来越多的app在注册或是进行对应操作时,要求获取短信验证码,在点击了获取短信验证码的按钮后,就是出现倒计时,比如倒计时120s,在倒计时期间内,按钮背景变化并且出现倒...

目前越来越多的app在注册或是进行对应操作时,要求获取短信验证码,在点击了获取短信验证码的按钮后,就是出现倒计时,比如倒计时120s,在倒计时期间内,按钮背景变化并且出现倒计时,当倒计时结束后,如果你没有获取到验证码,可以再次点击。

代码如下所示:

vercodetimer mvercodetimer=(button) findviewbyid(r.id.login_get_ver_code);
private class vercodetimer extends countdowntimer {
    private int seconds;
    private int interval;
    //millisinfuture为你设置的此次倒计时的总时长,比如60秒就设置为60000
    //countdowninterval为你设置的时间间隔,比如一般为1秒,根据需要自定义。
    public vercodetimer(long millisinfuture, long countdowninterval) {
      super(millisinfuture, countdowninterval);
      seconds = (int) (millisinfuture / 1000);
      interval= (int) (countdowninterval/1000);
    }
    //每过你规定的时间间隔做的操作
    @override
    public void ontick(long millisuntilfinished) {
      getvercodebutton.settext((seconds-interval) + "秒后重新获取");
    }
    //倒计时结束时做的操作↓↓
    @override
    public void onfinish() {
      getvercodebutton.settextsize(10);
      getvercodebutton.settext("重新获取验证码");
      getvercodebutton.setclickable(true);
      getvercodebutton.setbackgroundresource(r.drawable.login_get_ver_code_before_bg);
    }
  }
  
 @override
  public void onbackpressed() {
    if (mvercodetimer != null)
      mvercodetimer.cancel();
    super.onbackpressed();
  } 

使用的时候:

getvercodebutton.settextsize(11);
 getvercodebutton.setclickable(false);
 getvercodebutton.setbackgroundresource(r.drawable.login_get_ver_code_ago_bg);
 mvercodetimer = new vercodetimer(60000, 1000);
 mvercodetimer.start(); 

login_edit_normal_bg.xml:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
  android:shape="rectangle"
  android:uselevel="false">
  <!-- 背景填充颜色值 -->
  <solid android:color="#6c948b" />
  <!-- radius值越大,越趋于圆形 -->
  <corners android:radius="10dip" />
  <!-- 圆角图像内部填充四周的大小 ,将会以此挤压内部布置的view -->
  <padding
    android:bottom="10dip"
    android:left="10dip"
    android:right="10dip"
    android:top="10dip" />
</shape> 

login_edit_passed_bg.xml:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
  android:shape="rectangle"
  android:uselevel="false">
  <!-- 背景填充颜色值 -->
  <solid android:color="#509989" />
  <!-- radius值越大,越趋于圆形 -->
  <corners android:radius="10dip" />
  <!-- 圆角图像内部填充四周的大小 ,将会以此挤压内部布置的view -->
  <padding
    android:bottom="10dip"
    android:left="10dip"
    android:right="10dip"
    android:top="10dip" />
</shape>

以上所述是小编给大家介绍了android开发之获取短信验证码后按钮背景变化并且出现倒计时 的全部代码,希望本段代码能够帮助大家。同时感谢大家一直以来对网站的支持。