NStimer(计时器)实现按钮的发送验证码的一个小demo

原创 2015年11月17日 23:07:18

工程文件:
这里写图片描述

根视图控制器的代码不说了,主要的代码在
RootViewController.m中:

#import "RootViewController.h"

@interface RootViewController ()
//  直接赋值的不需要在dealloc中释放
//  将计数器的初始值设置成属性方便调用
@property (nonatomic,assign)NSInteger number;

@end

@implementation RootViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.

    UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom];
    //  设置按钮的相关属性
    btn.frame = CGRectMake(100, 100, 150, 50);
    btn.backgroundColor = [UIColor orangeColor];
    [btn setTitle:@"请输入验证码" forState:UIControlStateNormal];
    //  可以设置成属性或者tag值,这里使用tag值方法
    btn.tag = 1000;
    //  添加方法
    [btn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];


    //  添加到视图
    [self.view addSubview:btn];
    //  释放  方法创建不需要手动释放

    //  初始化计数器的值
    self.number = 5;

}

//  实现按钮点击方法
- (void)btnClick:(UIButton *)btn
{
    // 创建一个计数器 自动到0 之后重新发送
    // 此处的repeats属性只有YES时,才能实现自动计数
    NSTimer *timer = [NSTimer scheduledTimerWithTimeInterval:1.0 target:self selector:@selector(timerAction:) userInfo:@"button倒计时提示" repeats:YES];
    //  计时器开始
    [timer fire];

    //  必须关闭交互,不然每次点击都会产生一个计数器
    btn.userInteractionEnabled = NO;

}

- (void)timerAction:(NSTimer *)timer
{
    //  取出点击的Button
    UIButton *btn = (UIButton *)[self.view viewWithTag:1000];
    //  如果计数器的值为0时,显示为重新发送验证码
    //  判断计时器是否结束 就是他标题为0
    if ([[btn titleForState:UIControlStateNormal] isEqualToString:@"0"]) {
        //  计时器停止
        [timer invalidate];
        //  交互打开
        btn.userInteractionEnabled = YES;
        //  更改标题
        [btn setTitle:@"重新发送验证码" forState:UIControlStateNormal];
        //  重置计数器的值
        self.number = 5;
    }else{
        [btn setTitle:[NSString stringWithFormat:@"%ld",self.number--] forState:UIControlStateNormal];
    }
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}



@end

三维图
window->根视图->button
这里写图片描述

* 效果图*
这里写图片描述
这里写图片描述
这里写图片描述

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

iOS 验证码 小技术之 UIButton NSTimer 计时器

iOS 验证码 小技术之 NSTimer 计时器 UIButton

用Cookie来实现计时器(发送手机验证码、邮箱)

当我们在一个网站上注册时,要根据手机号码来获取验证码,而验证码中包括一个时间计数器。我们用普通的Js时间时间计数时就会出现当我们刷新页面的时候验证码计数器部消失了。所以这里我们想到了用Js来操作Coo...

计时器发送验证码(倒计时实现)

建立验证码按钮 //发送验证码按钮 _sentCodeBtn = [[UIButton alloc] initWithFrame:CGRectMake(kScreenWidth ...

iOS-计时器发送验证码

效果图如下: 定义一个发送验证码的按钮,添加点击事件 //发送验证码按钮 _sentCodeBtn = [[UIButton alloc] initWithFrame:CGRectM...

Android 验证码计时器 简单实现

需求实现发送验证码功能,发送之后倒计时60s之后可以重新发送。 实现xml布局文件 <LinearLayout android:id="@+id/linear_verify_c...

NSTimer实现的小计时器

  • 2015-11-07 14:47
  • 671KB
  • 下载

验证码发送按钮

预览图 1、自定义控件package com.jiangyy.demo;import android.content.Context; import android.content.res.Type...

验证码计时器-CountDownTimer就可以了

最近两个月项目赶得紧,没有学习什么新技术,就是对基础进行了巩固。每个安卓项目中都少不了登录注册的模块,既然有注册,那么获取验证码的功能是少不了的(都是固定套路)。其实获取验证码实现倒数计时的这个功能很...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)