这篇文章主要介绍了IOS实现验证码倒计时功能,点击获取验证码,进入时间倒计时,感兴趣的小伙伴们可以参考一下
验证码倒计时按钮的应用是非常普遍的,该Blog就和你一起来实现验证码倒计时的效果,定义一个发送验证码的按钮,添加点击事件,具体内容如下


具体代码:
定义一个发送验证码的按钮,添加点击事件
//发送验证码按钮
_sentCodeBtn = [[UIButton alloc] initWithFrame:CGRectMake(kScreenWidth - 27 - 4 - 94, CGRectGetMinY(_registerCodeFD.frame) + 4, 94, 40)];
[_sentCodeBtn setBackgroundColor:colorWithRGBA(0, 191, 191, 0.9)];
[_sentCodeBtn setTitle:@"发送验证码" forState:UIControlStateNormal];
[_sentCodeBtn.titleLabel setFont:[UIFont systemFontOfSize:13.0f]];
//设置圆角
[_sentCodeBtn.layer setCornerRadius:3.0f];
[_sentCodeBtn.layer setShouldRasterize:YES];
[_sentCodeBtn.layer setRasterizationScale:[UIScreen mainScreen].scale];
//发送事件
[_sentCodeBtn addTarget:self action:@selector(sentCodeMethod) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:_sentCodeBtn];
监听事件:
//发送验证码
-(void)sentCodeMethod{
NSLog(@"发送验证码。。");
//计时器发送验证码
[self sentPhoneCodeTimeMethod];
//调用发送验证码接口-》
}
//计时器发送验证码
-(void)sentPhoneCodeTimeMethod{
//倒计时时间 - 60秒
__block NSInteger timeOut = 59;
//执行队列
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
//计时器 -》dispatch_source_set_timer自动生成
dispatch_source_t timer = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0, queue);
dispatch_source_set_timer(timer, DISPATCH_TIME_NOW, 1.0 * NSEC_PER_SEC, 0 * NSEC_PER_SEC);
dispatch_source_set_event_handler(timer, ^{
if (timeOut <= 0) {
dispatch_source_cancel(timer);
//主线程设置按钮样式-》
dispatch_async(dispatch_get_main_queue(), ^{
[_sentCodeBtn setTitle:@"发送验证码" forState:UIControlStateNormal];
[_sentCodeBtn setUserInteractionEnabled:YES];
});
}else{
//开始计时
//剩余秒数 seconds
NSInteger seconds = timeOut % 60;
NSString *strTime = [NSString stringWithFormat:@"%.1ld",seconds];
//主线程设置按钮样式
dispatch_async(dispatch_get_main_queue(), ^{
[UIView beginAnimations:nil context:nil];
[UIView setAnimationDuration:1.0];
[_sentCodeBtn setTitle:[NSString stringWithFormat:@"%@S后重新发送",strTime] forState:UIControlStateNormal];
[UIView commitAnimations];
//计时器件不允许点击
[_sentCodeBtn setUserInteractionEnabled:NO];
});
timeOut--;
}
});
dispatch_resume(timer);
}
以上就是本文的全部内容,希望对大家的学习有所帮助。
织梦狗教程
本文标题为:IOS实现验证码倒计时功能(二)
基础教程推荐
猜你喜欢
- Flutter绘图组件之CustomPaint使用详解 2023-05-12
- IOS应用内跳转系统设置相关界面的方法 2022-11-20
- Flutter手势密码的实现示例(附demo) 2023-04-11
- Android中的webview监听每次URL变化实例 2023-01-23
- IOS 播放系统提示音使用总结(AudioToolbox) 2023-03-01
- Android多返回栈技术 2023-04-15
- Android开发使用RecyclerView添加点击事件实例详解 2023-06-15
- 解决Android Studio突然不显示logcat日志的问题 2023-02-04
- android studio按钮监听的5种方法实例详解 2023-01-12
- iOS开发教程之XLForm的基本使用方法 2023-05-01
