iOS 系統(tǒng)彈框展示擴展

Demo地址先上

 NSString *msg = @"1.如果你有女朋友\n2.請她吃東西?--你拉倒吧,吃胖了怎么辦.\n3.恩.我想跟你談戀愛?恩,你喜歡我,不關(guān)我事.\n4.追啊追...我的驕傲放縱";

系統(tǒng)的

Snip20170720_1.png

然而,我想要居左訂格的,比如用到版本更新提示的時候

UIAlertView

遍歷subviews 即可獲取msg對應的label,設置msglabel 居左屬性即可
省事啊,可是沒有margin ,效果貼邊怎么辦

NSInteger count = 0;
        for( UIView * view in alert.subviews )
        {
            if( [view isKindOfClass:[UILabel class]] )
            {
                count ++;
                if ( count == 2 ) { //僅對message左對齊
                    UILabel* label = (UILabel*) view;
                    //                    label.frame = CGRectMake(20, -20,200, size.height- 10);
                    label.textAlignment =NSTextAlignmentLeft;
                }
            }
        }

UIAlertController

UIAlertController獲取msg所屬的label,有一點點麻煩...不過總有父視圖,sub...sub...sub 總會找到的

UIView *subView1 = alertController.view.subviews[0];
    UIView *subView2 = subView1.subviews[0];
    UIView *subView3 = subView2.subviews[0];
    UIView *subView4 = subView3.subviews[0];
    NSLog(@"subvie4 - %@",subView4.subviews);

    UIView *subView5 = subView4.subviews[0];
    NSLog(@"subvie5 - %@",subView5.subviews);

來,看下控制臺輸出的

subvie4 - (
    "<UIView: 0x7ff520f09e60; frame = (0 0; 0 0); layer = <CALayer: 0x608000230a80>>"
)
subvie5 - (
    "<UILabel: 0x7ff520f0a390; frame = (0 0; 0 0); text = '\U4e0d\U4f1a\U8ffd,\U6211\U6559\U4f60\U554a'; userInteractionEnabled = NO; layer = <_UILabelLayer: 0x608000284ba0>>",
    "<UILabel: 0x7ff520f0aaa0; frame = (0 0; 0 0); text = '1.\U5982\U679c\U4f60\U6709\U5973\U670b\U53cb\n2.\U8bf7\U5979\U5403\U4e1c\U897f?--\U4f60\U62c9\U5012\U5427,...'; userInteractionEnabled = NO; layer = <_UILabelLayer: 0x608000284ce0>>",
    "<UIView: 0x7ff520f0af40; frame = (0 0; 0 0); clipsToBounds = YES; layer = <CALayer: 0x6080002309c0>>",
    "<UIView: 0x7ff520f0b0e0; frame = (0 0; 0 0); clipsToBounds = YES; layer = <CALayer: 0x60800022d7e0>>"
)

沒錯,多了兩個label,找到這倆坑貨了,別問我怎么區(qū)分誰是title ,誰是message的,沒錯---我試出來的.后面就可以隨意居左,居中,居右了

UILabel *lab_title = subView5.subviews[0];
UILabel *lab_message = subView5.subviews[1];
UIAlertAction *cancelAction = [UIAlertAction actionWithTitle:@"確定" style:UIAlertActionStyleDefault handler:nil];
 [alertController addAction:cancelAction];
lab_message.textAlignment = NSTextAlignmentLeft;
lab_title.textAlignment = NSTextAlignmentCenter;
[vc presentViewController:alertController animated:YES completion:nil];
Snip20170720_2.png

這樣是不是好一些啦?不好?哦~
什么?你想要彩色的標題?什么?你想要大號的message?可以啊,后面隨意啦~

//可富文本展示 -
     NSMutableAttributedString *alertControllerStr = [[NSMutableAttributedString alloc] initWithString:title];
     [alertControllerStr addAttribute:NSForegroundColorAttributeName value:[UIColor redColor] range:NSMakeRange(0, 2)];
     [alertControllerStr addAttribute:NSFontAttributeName value:[UIFont systemFontOfSize:20] range:NSMakeRange(3, 2)];
     [alertController setValue:alertControllerStr forKey:@"attributedTitle"];
     
//     修改message
     NSMutableAttributedString *alertControllerMessageStr = [[NSMutableAttributedString alloc] initWithString:message];
     [alertControllerMessageStr addAttribute:NSForegroundColorAttributeName value:[UIColor greenColor] range:NSMakeRange(0, 2)];
     [alertControllerMessageStr addAttribute:NSForegroundColorAttributeName value:[UIColor redColor] range:NSMakeRange(3, 4)];
     [alertControllerMessageStr addAttribute:NSFontAttributeName value:[UIFont systemFontOfSize:20] range:NSMakeRange(5, 3)];
     [alertController setValue:alertControllerMessageStr forKey:@"attributedMessage"];
//     修改按鈕的顏色
     [cancelAction setValue:[UIColor cyanColor] forKey:@"titleTextColor"];
Snip20170720_3.png

不過這個樣式有些固定,需要自己做range ,設置屬性,煩的死!那就自定義吧,加載html富文本樣式,后臺返回,移動端直接加載,那就來吧.
搜了些自定義的alert ,發(fā)現(xiàn)挺喜歡customiOSAlert這個的,高度自定義很方便(html 富文本,計算高度先,想要滾動的就加scrollow,想跟系統(tǒng)更接近,就把動畫去掉,按鈕弄弄,多個按鈕分割線,稍微改一下).下面是我項目中一些場景

NSString *htmlSr = @"<p>你好</p><p>        這是一個例子霎迫,請顯示</p><p>外加一個table</p><table><tbody><tr class=\"firstRow\"><td valign=\"top\" width=\"261\">aaaa</td><td valign=\"top\" width=\"261\">bbbb</td><td valign=\"top\" width=\"261\">cccc</td></tr></tbody></table><p></p>";
    
CustomIOSAlertView *alertView = [[CustomIOSAlertView alloc] init]; 
[alertView setContainerView:[self createView:htmlSr title:@"來"]];
[alertView setButtonTitles:@[@"確定",@"取消"]];
//    [alertView setDelegate:self];
[alertView setOnButtonTouchUpInside:^(CustomIOSAlertView *alertView, int buttonIndex) {
        NSLog(@"sett -ldd- %d",buttonIndex);
        [alertView close];
}];
[alertView setUseMotionEffects:true];
[alertView show];
Snip20170720_4.png

猿友們,拿去擼~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末矾麻,一起剝皮案震驚了整個濱河市拆座,隨后出現(xiàn)的幾起案子材彪,更是在濱河造成了極大的恐慌,老刑警劉巖觉痛,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件役衡,死亡現(xiàn)場離奇詭異,居然都是意外死亡薪棒,警方通過查閱死者的電腦和手機手蝎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來俐芯,“玉大人棵介,你說我怎么就攤上這事“墒罚” “怎么了邮辽?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長贸营。 經(jīng)常有香客問我吨述,道長,這世上最難降的妖魔是什么钞脂? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任揣云,我火速辦了婚禮,結(jié)果婚禮上芳肌,老公的妹妹穿的比我還像新娘灵再。我一直安慰自己,他們只是感情好亿笤,可當我...
    茶點故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著栋猖,像睡著了一般净薛。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蒲拉,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天肃拜,我揣著相機與錄音痴腌,去河邊找鬼。 笑死燃领,一個胖子當著我的面吹牛士聪,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播猛蔽,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼剥悟,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了曼库?” 一聲冷哼從身側(cè)響起区岗,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎毁枯,沒想到半個月后慈缔,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡种玛,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年藐鹤,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赂韵。...
    茶點故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡教藻,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出右锨,到底是詐尸還是另有隱情括堤,我是刑警寧澤,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布绍移,位于F島的核電站悄窃,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏蹂窖。R本人自食惡果不足惜轧抗,卻給世界環(huán)境...
    茶點故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望瞬测。 院中可真熱鬧横媚,春花似錦、人聲如沸月趟。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽孝宗。三九已至穷躁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間因妇,已是汗流浹背问潭。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工猿诸, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人狡忙。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓梳虽,卻偏偏與公主長得像,于是被迫代替她去往敵國和親灾茁。 傳聞我的和親對象是個殘疾皇子窜觉,可洞房花燭夜當晚...
    茶點故事閱讀 44,779評論 2 354

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn)删顶,斷路器竖螃,智...
    卡卡羅2017閱讀 134,654評論 18 139
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫逗余、插件特咆、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,102評論 4 62
  • 過年回家,參加了高中同學的聚會旗闽,這是畢業(yè)十五年以來,第一次參加同學聚會适室。這次聚會源于一個同學建的微信群,好久不...
    巧笑_倩兮_閱讀 461評論 5 1
  • 前陣子圖書日剛買回的書《學習之道》捣辆,今天打開書本有點如饑似渴的感覺蔬螟。 這本書是美國公認的學習第一書,它的作者喬掀耄·...
    剽悍文霞閱讀 307評論 0 5
  • 一旧巾、水火不容 我叫雷阿水,他叫丁四火忍些。 我的太陽星座是雙子,上升星座是天平坐昙。 他的太陽星座是射手,上升星座是天蝎炸客。...
    小霂閱讀 307評論 0 0