按钮倒计时的实现 iOS

42 篇文章 0 订阅
28 篇文章 0 订阅

很多项目中,都会涉及到倒计时的功能, 发送完验证码开始倒计时,针对这个我个人封装了一个简单的方法来实现此功能, 话不多说,上干货!

首先我是在UIButton的一个延展类里面添加了一个方法,

/**
 *  倒计时按钮
 *
 *  @param timeLine 倒计时总时间

 */

- (void)startCountDownWithTime:(NSInteger)timeLine

然后在.m中实现

- (void)startCountDownWithTime:(NSInteger)timeLine
{
    NSString *subTitle = @"重新发送";
    UIColor *defultColor = UGUColorFromRGB_0x(0xed145b);
    UIColor *runningColor = UGUColorFromRGB_0x(0xd5d5d5);

    //倒计时时间
    __block NSInteger timeOut = timeLine;
    dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
    dispatch_source_t _timer = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0, queue);
    //每秒执行一次
    dispatch_source_set_timer(_timer, dispatch_walltime(NULL, 0), 1.0 * NSEC_PER_SEC, 0);
    dispatch_source_set_event_handler(_timer, ^{

        //倒计时结束,关闭
        if (timeOut <= 0) {
            dispatch_source_cancel(_timer);
            dispatch_async(dispatch_get_main_queue(), ^{

                [self setTitle:subTitle forState:UIControlStateNormal];
                self.userInteractionEnabled = YES;
                self.layer.borderColor = [defultColor CGColor];
                [self setTitleColor:defultColor forState:UIControlStateNormal];

            });
        } else {

            self.userInteractionEnabled = YES;
            int allTime = (int)timeLine + 1;
            int seconds = timeOut % allTime;
            NSString *timeStr = [NSString stringWithFormat:@"%0.1d", seconds];
            dispatch_async(dispatch_get_main_queue(), ^{

                [self setTitle:[NSString stringWithFormat:@"%@%@",timeStr,@"s"] forState:UIControlStateNormal];
                self.layer.borderColor = [runningColor CGColor];
                [self setTitleColor:runningColor forState:UIControlStateNormal];

                self.userInteractionEnabled = NO;
            });
            timeOut--;
        }
    });
    dispatch_resume(_timer);
}

以上就是全部代码,怎么样 ,是不是感觉很简单呢?
希望可以帮到大家 ~~~~

传送门

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
由于苹果官方对iOS系统后台任务管控非常严格,所以在iOS系统要实现倒计时进入后台或者切换页面之后依然能保持倒计时状态会比较繁琐或困难,但倒计时按钮是经常用到、司空见惯!经常看到不太友好的倒计时按钮表现为,倒计时并未完成但当你切换页面或者进入后台后按钮倒计时失效并又可以点击了,实际上没有达到限制1~2分钟后才可点击的效果。于是我琢磨下封装了这个倒计时按钮的SDK它能解决上述问题并完美达到预期效果,而且SDK支持代码创建、XIB创建,使用也非常简单。注意这个SDK只能在真机上面跑,不能在xcode模拟器上面跑,因为时间匆忙没有做模拟器兼容SDK,请在真机上面使用SDK,下次有时间再更新。 SDK提供有比较灵活的属性控制,可修改倒计时按钮背景颜色、文字颜色、按钮圆角大小、点击时背景颜色,基本能满足全部UI设计需求。请下载资源包里面提供了SDK的用法截图、Demo、SDK(务必注意看看 5张SDK使用说明图片) 用法: 请直接把“SDK”文件夹拖到您的项目中,然后安照demo代码应用SDK即可,不明白请联系我们 注意1: 项目中有多个倒计时按钮,那么必须给按钮“indexsButtonLDS”设置不同的标识符(任意字符串),否则会出现异常。代码或者XIB方式设置indexsButtonLDS请参考代码,比较简单的(如果不明白仔细看下Demo) 注意2: 倒计时最长为180秒(因受iOS系统限制),超过180秒会无效。通常倒计时按钮都是限制2分钟吧。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值