最近在做获取验证码的功能,考虑到优良的用户体验,决定制作一个拥有倒计时提示的Button按钮,在网上查了一些资料,很是简单的就能实现,我写了一个小Demo,大家可以应用到自己的项目中。
一、代码
1.activity_main.xml:
- <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
- xmlns:tools="http://schemas.android.com/tools"
- android:layout_width="match_parent"
- android:layout_height="match_parent" >
-
- <Button
- android:id="@+id/btn_time"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:text="获取验证码" />
-
- </RelativeLayout>
2.MainActivity.java:
- package com.example.timebutton;
-
- import android.app.Activity;
- import android.os.Bundle;
- import android.os.CountDownTimer;
- import android.view.View;
- import android.view.View.OnClickListener;
- import android.view.Window;
- import android.widget.Button;
-
- public class MainActivity extends Activity {
- private Button mTimeButton;
- private TimeCount time;
-
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- requestWindowFeature(Window.FEATURE_NO_TITLE);
- setContentView(R.layout.activity_main);
- mTimeButton = (Button) findViewById(R.id.btn_time);
- time = new TimeCount(60000, 1000);
- mTimeButton.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) {
- mTimeButton.setEnabled(false);
- mTimeButton.setText(millisUntilFinished / 1000 + "秒");
- }
-
- @Override
- public void onFinish() {
- mTimeButton.setEnabled(true);
- mTimeButton.setText("重新获取");
-
- }
-
- }
-
- }
二、运行实例:
总结:CountDownTimer类的用法:
结构
继承关系
public abstract class CountDownTimer extends Object
java.lang.Object
android.os.CountDownTimer
类概述
定时执行在一段时候后停止的倒计时,在倒计时执行过程中会在固定间隔时间得到通知(译者:触发onTick方法),下面的例子显示在一个文本框中显示一个30s倒计时:
new CountdownTimer(30000, 1000) {
public void onTick(long millisUntilFinished) {
mTextField.setText("seconds remaining: " + millisUntilFinished / 1000);
}
public void onFinish() {
mTextField.setText("done!");
}
}.start();
onTick的调用是同步的,保证这次调用不会在之前调用完成前发生。这里的同步机制主要是用来:onTick的实现需要很多时间执行比倒计时间隔更重要的事情。
构造函数
public CountDownTimer (long millisInFuture, long countDownInterval)
参数
millisInFuture 从开始调用start()到倒计时完成并onFinish()方法被调用的毫秒数。(译者注:倒计时时间,单位毫秒)
countDownInterval 接收onTick(long)回调的间隔时间。(译者注:单位毫秒)
公共方法
public final void cancel ()
取消倒计时(译者:取消后,再次启动会重新开始倒计时)
public abstract void onFinish ()
倒计时完成时被调用
public abstract void onTick (long millisUntilFinished)
固定间隔被调用
参数
millisUntilFinished 倒计时剩余时间。
public synchronized final CountDownTimer start ()
启动倒计时