iOS開發(fā)--UIAlertController 簡單修改title以及按鈕的字體顏色

苦逼的開發(fā)者,最終敗給了一個任性的UI,系統(tǒng)原生UIAlertController的按紐顏色必須改.于是,開始了不歸路.
之前的版本是自己用view寫的一個仿系統(tǒng)UIActionSheet,動畫感覺都挺好,就是毛玻璃背景沒有系統(tǒng)的好,由于最低兼容了ios8,所以就拋棄了UIActionSheet,改用UIAlertController.

做法其實很簡單,采用runtime機制.對于runtime不了解的,我想還是別看各種介紹文章了,找一個簡單的demo多寫幾遍,就行了.

做法很簡單,自己寫一個類 繼承自UIAlertController,還是先把.h和.m的代碼都給大家吧.

SCAlertController.h

    //
    //  SCAlertController.h
    //  SCAlertController
    //
    //  Created by it3部01 on 16/8/3.
    //  Copyright ? 2016年 benben. All rights reserved.
    //
 
    #import <uikit uikit.h="">
 
    @interface SCAlertAction : UIAlertAction
 
      @property (nonatomic,strong) UIColor *textColor; /**< 按鈕title字體顏色 */
 
      @end
 
      @interface SCAlertController : UIAlertController
 
      @property (nonatomic,strong) UIColor *tintColor; /**< 統(tǒng)一按鈕樣式 不寫系統(tǒng)默認(rèn)的藍色 */
      @property (nonatomic,strong) UIColor *titleColor; /**< 標(biāo)題的顏色 */
      @property (nonatomic,strong) UIColor *messageColor; /**< 信息的顏色 */
 
    @end

SCAlertController.m
皇钞、综看、、
//  SCAlertController.m
//  SCAlertController
//
//  Created by it3部01 on 16/8/3.
//  Copyright ? 2016年 benben. All rights reserved.
//
#import "SCAlertController.h"
#import <objc runtime.h="">
 
@implementation SCAlertAction
 
//按鈕標(biāo)題的字體顏色
-(void)setTextColor:(UIColor *)textColor
{
    _textColor = textColor;
 
    unsigned int count = 0;
    Ivar *ivars = class_copyIvarList([UIAlertAction class], &count);
    for(int i =0;i < count;i ++){
 
        Ivar ivar = ivars[i];
        NSString *ivarName = [NSString stringWithCString:ivar_getName(ivar) encoding:NSUTF8StringEncoding];
 
        if ([ivarName isEqualToString:@"_titleTextColor"]) {
 
            [self setValue:textColor forKey:@"titleTextColor"];
        }
    }
}
 
@end
 
 
@implementation SCAlertController
 
-(void)viewDidLoad
{
    [super viewDidLoad];
 
    unsigned int count = 0;
    Ivar *ivars = class_copyIvarList([UIAlertController class], &count);
    for(int i = 0;i < count;i ++){
 
        Ivar ivar = ivars[i];
        NSString *ivarName = [NSString stringWithCString:ivar_getName(ivar) encoding:NSUTF8StringEncoding];
 
        //標(biāo)題顏色
        if ([ivarName isEqualToString:@"_attributedTitle"] && self.title && self.titleColor) {
 
            NSMutableAttributedString *attr = [[NSMutableAttributedString alloc]initWithString:self.title attributes:@{NSForegroundColorAttributeName:self.titleColor,NSFontAttributeName:[UIFont boldSystemFontOfSize:14.0]}];
            [self setValue:attr forKey:@"attributedTitle"];
        }
 
        //描述顏色
        if ([ivarName isEqualToString:@"_attributedMessage"] && self.message && self.messageColor) {
 
            NSMutableAttributedString *attr = [[NSMutableAttributedString alloc] initWithString:self.message attributes:@{NSForegroundColorAttributeName:self.messageColor,NSFontAttributeName:[UIFont systemFontOfSize:14.0]}];
            [self setValue:attr forKey:@"attributedMessage"];
        }
    }
 
    //按鈕統(tǒng)一顏色
    if (self.tintColor) {
        for (SCAlertAction *action in self.actions) {
            if (!action.textColor) {
                action.textColor = self.tintColor;
            }
        }
    }
}
 
@end

使用

SCAlertController *alertController = [SCAlertController alertControllerWithTitle:@"你確定要退出嗎?" message:nil preferredStyle:UIAlertControllerStyleActionSheet];
        alertController.tintColor = [UIColor redColor]; //這里統(tǒng)一設(shè)置各個按鈕的顏色都為紅色.
當(dāng)然,你還可以自定義某一個按鈕的顏色.比如下面的取消按鈕
        alertController.titleColor = [UIColor redColor];
 
        //取消
        SCAlertAction *cancelAction = [SCAlertAction actionWithTitle:@"我不想退出" style:UIAlertActionStyleCancel handler:nil];
 
        //單獨修改一個按鈕的顏色
        cancelAction.textColor = [UIColor greenColor];
        [alertController addAction:cancelAction];
 
        //退出
        SCAlertAction *exitAction = [SCAlertAction actionWithTitle:@"退出" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {
 
        }];
        [alertController addAction:exitAction];
 
        [self presentViewController:alertController animated:YES completion:nil];
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末绷落,一起剝皮案震驚了整個濱河市嫌吠,隨后出現(xiàn)的幾起案子瘾蛋,更是在濱河造成了極大的恐慌营搅,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件梆砸,死亡現(xiàn)場離奇詭異剧防,居然都是意外死亡,警方通過查閱死者的電腦和手機辫樱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進店門峭拘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人狮暑,你說我怎么就攤上這事鸡挠。” “怎么了搬男?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵拣展,是天一觀的道長。 經(jīng)常有香客問我缔逛,道長备埃,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任褐奴,我火速辦了婚禮按脚,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘敦冬。我一直安慰自己辅搬,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布脖旱。 她就那樣靜靜地躺著堪遂,像睡著了一般。 火紅的嫁衣襯著肌膚如雪萌庆。 梳的紋絲不亂的頭發(fā)上溶褪,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天,我揣著相機與錄音践险,去河邊找鬼猿妈。 笑死,一個胖子當(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
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年坯癣,在試婚紗的時候發(fā)現(xiàn)自己被綠了瓶盛。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡示罗,死狀恐怖惩猫,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情蚜点,我是刑警寧澤轧房,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站绍绘,受9級特大地震影響奶镶,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜陪拘,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一厂镇、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧左刽,春花似錦剪撬、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至斋否,卻和暖如春梨水,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背茵臭。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工疫诽, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人旦委。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓奇徒,卻偏偏與公主長得像,于是被迫代替她去往敵國和親缨硝。 傳聞我的和親對象是個殘疾皇子摩钙,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,627評論 2 350

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