iOS開發(fā) - 短信驗證碼倒計時按鈕的實現(xiàn)

個人博客: LiCheng的博客

引言:

驗證碼倒計時按鈕的應(yīng)用是非常普遍的成翩,本文介紹了IOS實現(xiàn)驗證碼倒計時功能,點擊獲取驗證碼辰妙,進入時間倒計時康嘉,感興趣的小伙伴們可以參考一下:

效果圖

實現(xiàn)思路:

  • 創(chuàng)建按鈕, 添加點擊方法;
  • 用NSTimer定時器, 每秒執(zhí)行一次, 定時改變Button的title,改變Button的樣式, 設(shè)置Button不可點擊;
  • 若倒計時結(jié)束, 定時器關(guān)閉, 并改變Button的樣式, 可以點擊;

代碼如下:

在按鈕的點擊事件里調(diào)用該方法.

// 開啟倒計時效果
-(void)openCountdown{

    __block NSInteger time = 59; //倒計時時間
    
    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); //每秒執(zhí)行
    
    dispatch_source_set_event_handler(_timer, ^{
        
        if(time <= 0){ //倒計時結(jié)束,關(guān)閉
            
            dispatch_source_cancel(_timer);
            dispatch_async(dispatch_get_main_queue(), ^{

                //設(shè)置按鈕的樣式
                [self.authCodeBtn setTitle:@"重新發(fā)送" forState:UIControlStateNormal];
                [self.authCodeBtn setTitleColor:[UIColor colorFromHexCode:@"FB8557"] forState:UIControlStateNormal];
                self.authCodeBtn.userInteractionEnabled = YES;
            });

        }else{
            
            int seconds = time % 60;
            dispatch_async(dispatch_get_main_queue(), ^{

                //設(shè)置按鈕顯示讀秒效果
                [self.authCodeBtn setTitle:[NSString stringWithFormat:@"重新發(fā)送(%.2d)", seconds] forState:UIControlStateNormal];
                [self.authCodeBtn setTitleColor:[UIColor colorFromHexCode:@"979797"] forState:UIControlStateNormal];
                self.authCodeBtn.userInteractionEnabled = NO;
            });
            time--;
        }
    });
    dispatch_resume(_timer);
}

注意點:

我們在創(chuàng)建Button時, 要設(shè)置Button的樣式:
當(dāng)type為: UIButtonTypeCustom時 , 是讀秒的效果.
當(dāng)type為: 其他時, 是一閃一閃的效果.
<br />


GitHub: https://github.com/LiCheng244/LCUtils
個人博客: http://www.licheng244.com/


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末巩割,一起剝皮案震驚了整個濱河市裙顽,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌宣谈,老刑警劉巖愈犹,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異闻丑,居然都是意外死亡漩怎,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門嗦嗡,熙熙樓的掌柜王于貴愁眉苦臉地迎上來勋锤,“玉大人,你說我怎么就攤上這事侥祭∪矗” “怎么了茄厘?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長徒恋。 經(jīng)常有香客問我蚕断,道長,這世上最難降的妖魔是什么入挣? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任亿乳,我火速辦了婚禮,結(jié)果婚禮上径筏,老公的妹妹穿的比我還像新娘葛假。我一直安慰自己,他們只是感情好滋恬,可當(dāng)我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布聊训。 她就那樣靜靜地躺著,像睡著了一般恢氯。 火紅的嫁衣襯著肌膚如雪带斑。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天勋拟,我揣著相機與錄音勋磕,去河邊找鬼。 笑死敢靡,一個胖子當(dāng)著我的面吹牛挂滓,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播啸胧,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼赶站,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了纺念?” 一聲冷哼從身側(cè)響起贝椿,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎陷谱,沒想到半個月后团秽,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡叭首,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年习勤,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片焙格。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡图毕,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出眷唉,到底是詐尸還是另有隱情予颤,我是刑警寧澤囤官,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站蛤虐,受9級特大地震影響党饮,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜驳庭,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一刑顺、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧饲常,春花似錦蹲堂、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至播聪,卻和暖如春朽基,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背离陶。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工稼虎, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人枕磁。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓渡蜻,卻偏偏與公主長得像术吝,于是被迫代替她去往敵國和親计济。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,828評論 2 345

推薦閱讀更多精彩內(nèi)容