iOS UIAlertController中UITextField添加晃動(dòng)效果與邊框顏色詳解
前言
大家都知道在iOS8中引入了UIAlertController,通過(guò)UIAlertController可以方便的添加文本框進(jìn)行編輯,但是,在輸入錯(cuò)誤的內(nèi)容時(shí),如何對(duì)用戶(hù)進(jìn)行提醒就成了問(wèn)題,因?yàn)閁IAlertController中的所有UIAlertAction都會(huì)導(dǎo)致UIAlertController的消失。這里,我就描述兩種提示的方法,分別是晃動(dòng)文本框和修改邊框的顏色。下面話(huà)不多說(shuō)了,來(lái)一起看看詳細(xì)的實(shí)現(xiàn)方法吧。
晃動(dòng)UITextField
晃動(dòng)UITextField其實(shí)就是對(duì)它添加一個(gè)動(dòng)畫(huà)效果,參考了Stack Overflow上的做法,通過(guò)添加position的動(dòng)畫(huà),可以實(shí)現(xiàn)UIAlertController中的UITextField的晃動(dòng)效果。
- (void)shakeField:(UITextField *)textField { CABasicAnimation *animation = [CABasicAnimation animationWithKeyPath:@"position"]; animation.duration = 0.07; animation.repeatCount = 4; animation.autoreverses = YES; animation.fromValue = [NSValue valueWithCGPoint:CGPointMake(textField.centerX - 10, textField.centerY)]; animation.toValue = [NSValue valueWithCGPoint:CGPointMake(textField.centerX + 10, textField.centerY)]; [textField.layer addAnimation:animation forKey:@"position"]; }
修改UITextField的邊框顏色
UIAlertController中文本框的默認(rèn)邊框顏色都是黑色,通常在輸入異常時(shí)會(huì)改為紅色進(jìn)行提醒,這個(gè)時(shí)候,如果直接修改UITextField的border將會(huì)變成下圖樣式:
- (void)testAlert { UIAlertController *alert = [UIAlertController alertControllerWithTitle:@"測(cè)試" message:@"測(cè)試輸入框邊框顏色" preferredStyle:UIAlertControllerStyleAlert]; [alert addAction:[UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil]]; [alert addTextFieldWithConfigurationHandler:^(UITextField * _Nonnull textField) { textField.layer.borderColor = [UIColor redColor].CGColor; textField.layer.borderWidth = 1; }]; [self presentViewController:alert animated:YES completion:nil]; }
而在實(shí)際中我們應(yīng)該這樣修改:
- (void)testAlert { UIAlertController *alert = [UIAlertController alertControllerWithTitle:@"測(cè)試" message:@"測(cè)試輸入框邊框顏色" preferredStyle:UIAlertControllerStyleAlert]; [alert addAction:[UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil]]; [alert addTextFieldWithConfigurationHandler:^(UITextField * _Nonnull textField) { self.currentField = textField; }]; [self presentViewController:alert animated:YES completion:^{ [[self.currentField superview] superview].backgroundColor = [UIColor redColor]; }]; }
這樣的產(chǎn)生效果才是我們想要的。
需要注意的是:一定要在present以后進(jìn)行設(shè)置,否則會(huì)發(fā)現(xiàn)設(shè)置是無(wú)效的,因?yàn)闆](méi)有present之前,textField的superview是nil,設(shè)置是無(wú)效的。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,本文還有許多不足,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
iOS Moya實(shí)現(xiàn)OAuth請(qǐng)求的方法
這篇文章主要介紹了iOS Moya實(shí)現(xiàn)OAuth請(qǐng)求的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12iOS開(kāi)發(fā)微信收款到賬語(yǔ)音提醒功能思路詳解
這篇文章主要介紹了iOS開(kāi)發(fā)微信收款到賬語(yǔ)音提醒功能思路詳解,需要的朋友可以參考下2017-09-09iOS系統(tǒng)和微信中不支持audio自動(dòng)播放問(wèn)題的解決方法
最近在微信端開(kāi)發(fā)H5的時(shí)候,audio標(biāo)簽在蘋(píng)果機(jī)上無(wú)法進(jìn)行自動(dòng)播放,查找相關(guān)資料終于解決了,所以下面這篇文章主要給大家介紹了關(guān)于iOS系統(tǒng)和微信中不支持audio自動(dòng)播放問(wèn)題的解決方法,需要的朋友可以參考下。2017-09-09iOS判斷網(wǎng)絡(luò)請(qǐng)求超時(shí)的方法
本篇文章主要介紹了iOS判斷網(wǎng)絡(luò)請(qǐng)求超時(shí)的方法,現(xiàn)在分享給大家,也給大家做個(gè)參考。感興趣的小伙伴們可以參考一下。2016-12-12實(shí)例講解iOS應(yīng)用開(kāi)發(fā)中UIPickerView滾動(dòng)選擇欄的用法
這篇文章主要介紹了iOS應(yīng)用開(kāi)發(fā)中UIPickerView滾動(dòng)選擇欄的用法,示例代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-04-04iOS開(kāi)發(fā)之1行代碼實(shí)現(xiàn)緩存計(jì)算及清除緩存
這篇文章主要給大家介紹了關(guān)于iOS開(kāi)發(fā)之1行代碼實(shí)現(xiàn)緩存計(jì)算及清除緩存的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)各位iOS開(kāi)發(fā)者們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05iOS開(kāi)發(fā)探索多線(xiàn)程GCD隊(duì)列示例詳解
這篇文章主要為大家介紹了iOS開(kāi)發(fā)探索多線(xiàn)程GCD隊(duì)列示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07iOS實(shí)現(xiàn)簡(jiǎn)單的頭部縮放功能
這篇文章主要介紹了iOS 簡(jiǎn)單的頭部縮放效果,頭部伴隨模糊效果放大縮小,并在一定位置時(shí)懸停充當(dāng)導(dǎo)航欄,本文給大家提供實(shí)現(xiàn)思路,需要的朋友可以參考下2018-08-08