Android 实现点击按钮获取验证码 60秒后重新获取效果

本文介绍了一个简单的倒计时定时器实现方法,通过Android的CountDownTimer类完成验证码发送后的倒计时逻辑,包括按钮状态及背景颜色的变化。
功能非常简单就是定义一个CountDownTimer。

package com.example.countdowntimer;
  
  
  
import android.os.Bundle;
import android.os.CountDownTimer;
import android.app.Activity;
import android.graphics.Color;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
  
public class MainActivity extends Activity {
    private TimeCount time;
    private Button btnGetcode;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        time = new TimeCount(60000, 1000);
        btnGetcode=(Button) findViewById(R.id.btn_getcode);
        btnGetcode.setOnClickListener(new OnClickListener() {
              
            @Override
            public void onClick(View v) {
                time.start();
            }
        });
    }
    class TimeCount extends CountDownTimer {
  
        public TimeCount(long millisInFuture, long countDownInterval) {
            super(millisInFuture, countDownInterval);
        }
  
        @Override
        public void onTick(long millisUntilFinished) {
            btnGetcode.setBackgroundColor(Color.parseColor("#B6B6D8"));
            btnGetcode.setClickable(false);
            btnGetcode.setText("("+millisUntilFinished / 1000 +") 秒后可重新发送");
        }
  
        @Override
        public void onFinish() {
            btnGetcode.setText("重新获取验证码");
            btnGetcode.setClickable(true);
            btnGetcode.setBackgroundColor(Color.parseColor("#4EB84A"));
  
        }
    }
  
}

获取验证码的功能需要用到 Android 中的计时器(CountDownTimer)和短信验证。以下是一种简单的实现方式: 1. 在 XML 布局文件中添加一个按钮和一个 EditText,用于用户输入手机号码: ``` <EditText android:id="@+id/et_phone_number" android:layout_width="match_parent" android:layout_height="wrap_content" android:hint="请输入手机号码"/> <Button android:id="@+id/btn_get_verification_code" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="获取验证码"/> ``` 2. 在 Activity 中找到这两个控件,并设置按钮点击事件: ```java public class MainActivity extends AppCompatActivity { private EditText etPhoneNumber; private Button btnGetVerificationCode; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); etPhoneNumber = findViewById(R.id.et_phone_number); btnGetVerificationCode = findViewById(R.id.btn_get_verification_code); // 设置按钮点击事件 btnGetVerificationCode.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 获取用户输入的手机号码 String phoneNumber = etPhoneNumber.getText().toString(); // TODO: 调用短信验证 API,发送验证码 // 启动倒计时器 startCountDown(); } }); } // 启动倒计时器 private void startCountDown() { // 创建一个计时器,设置时间间隔为 1 ,总时间为 60 CountDownTimer countDownTimer = new CountDownTimer(60000, 1000) { // 时间间隔结束调用方法 @Override public void onTick(long millisUntilFinished) { // 更新按钮上的文字 btnGetVerificationCode.setText(millisUntilFinished / 1000 + " 重新发送"); // 禁用按钮 btnGetVerificationCode.setEnabled(false); } // 总时间结束调用方法 @Override public void onFinish() { // 更新按钮上的文字 btnGetVerificationCode.setText("获取验证码"); // 启用按钮 btnGetVerificationCode.setEnabled(true); } }; // 启动计时器 countDownTimer.start(); } } ``` 注意:上述代码中关于短信验证的部分需要自己调用相应的 API 实现
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值