Android自定义View获取注册验证码倒计时按钮,android videoview

3
回复
521
查看
[复制链接]

501

主题

1168

帖子

2061

安币

手工艺人

发表于 2017-12-26 15:14:46 | 显示全部楼层 |阅读模式

        在android开发中,我们不可避免的会做到注册功能,而现在的注册大多数都是用手机去注册的,那么注册的时候都会要求用获取验证码的方式去验证,我们接下来就来实战一下自定义获取验证码倒计时按钮:

        1.先看效果图

        

        2.我们涉及到的变量

[Java] 查看源文件 复制代码
//倒计时时长,可设置

/**
 * 倒计时时长,默认倒计时时间60秒;
 */
private long length = 60 * 1000;

//在点击按钮之前按钮所显示的文字

/**
 * 在点击按钮之前按钮所显示的文字,默认是获取验证码
 */
private string beforetext = "获取验证码";

//在开始倒计时之后那个秒数数字之后所要显示的字

/**
 * 在开始倒计时之后那个秒数数字之后所要显示的字,默认是秒
 */
private string aftertext = "秒";

        3.利用什么倒计时timer

        在java中定时器任务的执行需要两个基本的类:
java.util.timer;
java.util.timertask;

        要运行一个定时任务,最基本的步骤如下:
1、建立一个要执行的任务timertask。
2、创建一个timer实例,通过timer提供的schedule()方法,将 timertask加入到定时器timer中,同时设置执行的规则即可。

        当程序执行了timer初始化代码后,timer定时任务就会按照设置去执行。
timer中的schedule()方法是有多种重载格式的,以适应不同的情况。该方法的格式如下:
void schedule(timertask task, date time)
安排在指定的时间执行指定的任务。
void schedule(timertask task, date firsttime, long period)
安排指定的任务在指定的时间开始进行重复的固定延迟执行。
void schedule(timertask task, long delay)
安排在指定延迟后执行指定的任务。
void schedule(timertask task, long delay, long period)
安排指定的任务从指定的延迟后开始进行重复的固定延迟执行。
timer是线程安全的,此类可扩展到大量同时安排的任务(存在数千个都没有问题)。其所有构造方法都启动计时器线程。可以调用cancel() 终止此计时器,丢弃所有当前已安排的任务。purge()从此计时器的任务队列中移除所有已取消的任务。此类不提供实时保证:它使用 object.wait(long) 方法来安排任务。
timertask是一个抽象类,由 timer 安排为一次执行或重复执行的任务。它有一个抽象方法run()―-计时器任务要执行的操作。因此,每个具体的任务类都必须继承timertask类,并且重写run()方法。另外它还有两个非抽象的方法:
boolean cancel()
取消此计时器任务。
long scheduledexecutiontime()
返回此任务最近实际 执行的安排 执行时间。

        4.代码

[Java] 查看源文件 复制代码
import android.content.context;
import android.os.handler;
import android.os.message;
import android.text.textutils;
import android.util.attributeset;
import android.view.view;
import android.widget.button;

import java.util.timer;
import java.util.timertask;

/**
 * 自定义倒计时按钮
 * <p/>
 *
 * @author dylan
 *     [佛祖保佑 永无bug]
 *     created by dylan on 2016/10/5 0005.
 */
public class countdownbutton extends button implements view.onclicklistener {
  /**
   * 倒计时时长,默认倒计时时间60秒;
   */
  private long length = 60 * 1000;
  /**
   * 开始执行计时的类,可以在每秒实行间隔任务
   */
  private timer timer;
  /**
   * 每秒时间到了之后所执行的任务
   */
  private timertask timertask;
  /**
   * 在点击按钮之前按钮所显示的文字,默认是获取验证码
   */
  private string beforetext = "获取验证码";
  /**
   * 在开始倒计时之后那个秒数数字之后所要显示的字,默认是秒
   */
  private string aftertext = "秒";
  /**
   * 按钮点击事件
   */
  private onclicklistener onclicklistener;


  public countdownbutton(context context) {
    super(context);
    initview();
  }

  public countdownbutton(context context, attributeset attrs) {
    super(context, attrs);
    initview();
  }

  public countdownbutton(context context, attributeset attrs, int defstyleattr) {
    super(context, attrs, defstyleattr);
    initview();
  }

  /**
   * 初始化操作
   */
  private void initview() {
    if (!textutils.isempty(gettext())) {
      beforetext = gettext().tostring().trim();
    }
    this.settext(beforetext);
    setonclicklistener(this);
  }

  /**
   * 初始化时间
   */
  private void inittimer() {
    timer = new timer();
    timertask = new timertask() {
      @override
      public void run() {
        handler.sendemptymessage(1);
      }
    };
  }

  /**
   * 设置倒计时时长
   *
   * @param length 默认毫秒
   */
  public void setlength(long length) {
    this.length = length;
  }

  /**
   * 设置未点击时显示的文字
   *
   * @param beforetext
   */
  public void setbeforetext(string beforetext) {
    this.beforetext = beforetext;
  }

  /**
   * 设置未点击后显示的文字
   *
   * @param beforetext
   */
  public void setaftertext(string beforetext) {
    this.aftertext = aftertext;
  }

  /**
   * 设置监听按钮点击事件
   *
   * @param onclicklistener
   */
  @override
  public void setonclicklistener(onclicklistener onclicklistener) {
    if (onclicklistener instanceof countdownbutton) {
      super.setonclicklistener(onclicklistener);
    } else {
      this.onclicklistener = onclicklistener;
    }
  }

  /**
   * 点击按钮后的操作
   *
   * @param v
   */
  @override
  public void onclick(view v) {
    start();
    if (onclicklistener != null) {
      onclicklistener.onclick(v);
    }
  }

  /**
   * 开始倒计时
   */
  public void start() {
    inittimer();
    this.settext(length / 1000 + aftertext);
    this.setenabled(false);
    timer.schedule(timertask, 0, 1000);
  }


  /**
   * 更新显示的文本
   */
  private handler handler = new handler() {
    @override
    public void handlemessage(message msg) {
      super.handlemessage(msg);
      countdownbutton.this.settext(length / 1000 + aftertext);
      length -= 1000;
      if (length < 0) {
        countdownbutton.this.setenabled(true);
        countdownbutton.this.settext(beforetext);
        cleartimer();
        length = 60 * 1000;
      }
    }
  };

  /**
   * 清除倒计时
   */
  private void cleartimer() {
    if (timertask != null) {
      timertask.cancel();
      timertask = null;
    }
    if (timer != null) {
      timer.cancel();
      timer = null;
    }
  }

  /**
   * 记得一定要在activity或者fragment消亡的时候清除倒计时,
   * 因为如果倒计时没有完的话子线程还在跑,
   * 这样的话就会引起内存溢出
   */
  @override
  protected void ondetachedfromwindow() {
    cleartimer();
    super.ondetachedfromwindow();
  }
}

        5.用法,超级简单

[Java] 查看源文件 复制代码
 <com.bm.ykzx.view.countdownbutton
        android:id="@+id/cdb_register_timer"
        android:layout_width="120dp"
        android:textallcaps="false"
        android:layout_height="match_parent"
        android:background="@android:color/transparent"
        android:gravity="center"
        android:paddingleft="3dp"
        android:paddingright="3dp"
        android:text="获取验证码"
        android:textcolor="#1179c4"
        android:textsize="@dimen/txt14sp" />


28

主题

1万

帖子

1369

安币

Android大神

小白

Rank: 6Rank: 6

发表于 2017-12-27 08:47:34 | 显示全部楼层
感谢分享,楼主V5~

3

主题

9437

帖子

1796

安币

Android大神

Rank: 6Rank: 6

QQ达人

发表于 2017-12-28 05:59:31 | 显示全部楼层
帮帮顶顶!!

20

主题

9237

帖子

2344

安币

Android大神

Rank: 6Rank: 6

发表于 2017-12-29 17:06:11 | 显示全部楼层
感谢分享,安卓巴士有你更精彩:lol
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

领先的中文移动开发者社区
18620764416
7*24全天服务
意见反馈:1294855032@qq.com

扫一扫关注我们

Powered by Discuz! X3.2© 2001-2019 Comsenz Inc.( 粤ICP备15117877号 )