iOS開發(fā) - 自定義UIAlertController的樣式

個人博客: LiCheng的博客

引言:

關(guān)于提示框, 系統(tǒng)自帶的提示框有時可能滿足不了我們的需求, 比如一個提示框的取消按鈕我需要灰色字體顯示, 這時候就需要自定義提示框的樣式了。

示例圖
蘋果自iOS8開始燥筷,就已經(jīng)廢棄了之前用于界面提醒的UIAlertView類以及UIActionSheet,取而代之的是UIAlertController以及UIAlertAction,從實(shí)際使用情況來看,蘋果把之前不同類型/樣式的通知實(shí)現(xiàn)方法進(jìn)行了統(tǒng)一盾沫,簡化了有關(guān)提醒功能的實(shí)現(xiàn)嗤疯。

UIAlertController的基本使用

一個簡單的提示框:

    UIAlertController *alert    = [UIAlertController alertControllerWithTitle:@"標(biāo)題" message:@"正文" preferredStyle:(UIAlertControllerStyleAlert)];

    UIAlertAction *okAction     = [UIAlertAction actionWithTitle:@"確定" style:(UIAlertActionStyleDefault) handler:^(UIAlertAction * _Nonnull action) {
        // 點(diǎn)擊確定按鈕時 要進(jìn)行的操作可以寫到這里
    }];
    UIAlertAction *cancelAction = [UIAlertAction actionWithTitle:@"取消" style:(UIAlertActionStyleCancel) handler:^(UIAlertAction * _Nonnull action) {
        // 點(diǎn)擊取消按鈕時 要進(jìn)行的操作可以寫到這里
    }];
    
    [alert addAction:cancelAction];
    [alert addAction:okAction];

    [self presentViewController:alert animated:YES completion:nil];

自定義UIAlertController

主要是使用kvc的方式來自定義UIAlertController的樣式:

    UIAlertController *alert = [UIAlertController alertControllerWithTitle:@"標(biāo)題" message:@"內(nèi)容" preferredStyle:UIAlertControllerStyleAlert];
    
    // 使用富文本來改變alert的title字體大小和顏色
    NSMutableAttributedString *titleText = [[NSMutableAttributedString alloc] initWithString:@"這里是標(biāo)題"];
    [titleText addAttribute:NSFontAttributeName value:[UIFont systemFontOfSize:24] range:NSMakeRange(0, 2)];
    [titleText addAttribute:NSForegroundColorAttributeName value:[UIColor redColor] range:NSMakeRange(0, 2)];
    [alert setValue:titleText forKey:@"attributedTitle"];
    
    // 使用富文本來改變alert的message字體大小和顏色
    // NSMakeRange(0, 2) 代表:從0位置開始 兩個字符
    NSMutableAttributedString *messageText = [[NSMutableAttributedString alloc] initWithString:@"這里是正文信息"];
    [messageText addAttribute:NSFontAttributeName value:[UIFont systemFontOfSize:10] range:NSMakeRange(0, 6)];
    [messageText addAttribute:NSForegroundColorAttributeName value:[UIColor redColor] range:NSMakeRange(0, 2)];
    [messageText addAttribute:NSForegroundColorAttributeName value:[UIColor brownColor] range:NSMakeRange(3, 3)];
    [alert setValue:messageText forKey:@"attributedMessage"];


    UIAlertAction *cancelAction = [UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil];
    
    // 設(shè)置按鈕背景圖片
    UIImage *accessoryImage = [[UIImage imageNamed:@"selectRDImag.png"] imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
    [cancelAction setValue:accessoryImage forKey:@"image"];
    
    // 設(shè)置按鈕的title顏色
    [cancelAction setValue:[UIColor lightGrayColor] forKey:@"titleTextColor"];
    
    // 設(shè)置按鈕的title的對齊方式
    [cancelAction setValue:[NSNumber numberWithInteger:NSTextAlignmentLeft] forKey:@"titleTextAlignment"];
    
    UIAlertAction *okAction = [UIAlertAction actionWithTitle:@"確認(rèn)" style:UIAlertActionStyleDefault handler:nil];

    [alert addAction:okAction];
    [alert addAction:cancelAction];

    [self presentViewController:alert animated:YES completion:nil];

效果圖:

效果圖

demo下載地址:CustomAlertControllerDemo
<br />


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


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市经宏,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌驯击,老刑警劉巖烁兰,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異徊都,居然都是意外死亡沪斟,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進(jìn)店門暇矫,熙熙樓的掌柜王于貴愁眉苦臉地迎上來主之,“玉大人,你說我怎么就攤上這事袱耽∩辈停” “怎么了?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵朱巨,是天一觀的道長史翘。 經(jīng)常有香客問我,道長冀续,這世上最難降的妖魔是什么琼讽? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮洪唐,結(jié)果婚禮上钻蹬,老公的妹妹穿的比我還像新娘。我一直安慰自己凭需,他們只是感情好问欠,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著粒蜈,像睡著了一般顺献。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上枯怖,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天注整,我揣著相機(jī)與錄音,去河邊找鬼。 笑死肿轨,一個胖子當(dāng)著我的面吹牛寿冕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播椒袍,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼驼唱,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了槐沼?” 一聲冷哼從身側(cè)響起曙蒸,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎岗钩,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體肖油,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡兼吓,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了森枪。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片视搏。...
    茶點(diǎn)故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖县袱,靈堂內(nèi)的尸體忽然破棺而出浑娜,到底是詐尸還是另有隱情,我是刑警寧澤式散,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布筋遭,位于F島的核電站,受9級特大地震影響暴拄,放射性物質(zhì)發(fā)生泄漏漓滔。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一乖篷、第九天 我趴在偏房一處隱蔽的房頂上張望响驴。 院中可真熱鬧,春花似錦撕蔼、人聲如沸豁鲤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽琳骡。三九已至,卻和暖如春诉探,著一層夾襖步出監(jiān)牢的瞬間日熬,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留竖席,地道東北人耘纱。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓,卻偏偏與公主長得像毕荐,于是被迫代替她去往敵國和親束析。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,627評論 2 350

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