iOS 15 適配和新特性

1候醒、蘋果對導(dǎo)航欄的性能做了優(yōu)化,默認(rèn)情況下次慢,如果導(dǎo)航欄與視圖沒有折疊,導(dǎo)航欄的背景透明翔曲,如果系統(tǒng)檢測到有重疊的話迫像,會變成毛玻璃的效果

if (@available(iOS 15.0, *)) {
NSDictionary *textAttr = @{
                                   NSForegroundColorAttributeName : [UIColor whiteColor],
                                   NSFontAttributeName: [UIFont systemFontOfSize:17],
                                   };
    UINavigationBarAppearance *appearance = [[UINavigationBarAppearance alloc] init];
    [appearance setShadowImage:[[UIImage alloc] init]];
appearance.titleTextAttributes = textAttr;
    [appearance setBackgroundColor:TAD_THM.navigationBackgroundColor];
    // 隱藏分割線 設(shè)置一個(gè)透明或者純色的圖片 設(shè)置nil 或者 [UIImage new]無效
    [appearance setBackgroundImage:[UIImage zt_imageWithPureColor:[UIColor whiteColor]]];
    [appearance setShadowImage:[UIImage zt_imageWithPureColor:[UIColor whiteColor]]];

    [[UINavigationBar appearance] setScrollEdgeAppearance: appearance];
// 滾動頁面 防止導(dǎo)航欄會變白色
[[UINavigationBar appearance] setStandardAppearance:appearance];

        [[UINavigationBar appearance] setCompactAppearance:appearance];

// 隱藏導(dǎo)航欄底部一個(gè)線條
            [self.navigationController.navigationBar.subviews.firstObject.subviews enumerateObjectsUsingBlock:^(__kindof UIView * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
                if ([obj isKindOfClass:NSClassFromString(@"_UIBarBackgroundShadowContentImageView")] || [obj isKindOfClass:NSClassFromString(@"_UIBarBackgroundShadowView")]) {
                    obj.hidden=YES;
                }
            }];
}

顏色轉(zhuǎn)圖片

+ (UIImage *)zt_imageWithPureColor:(UIColor *)color {
    UIGraphicsBeginImageContextWithOptions(CGSizeMake(3, 3), NO, [UIScreen mainScreen].scale);
    UIBezierPath* p = [UIBezierPath bezierPathWithRect:CGRectMake(0, 0, 3, 3)];
    [color setFill];
    [p fill];
    UIImage* img = UIGraphicsGetImageFromCurrentImageContext();
    return img;
}
+ (UIImage *)zt_imageWithPureColor:(UIColor *)color size:(CGSize )size{
    UIGraphicsBeginImageContextWithOptions(size, NO, [UIScreen mainScreen].scale);
    UIBezierPath* p = [UIBezierPath bezierPathWithRect:CGRectMake(0, 0, size.width, size.height)];
    [color setFill];
    [p fill];
    UIImage* img = UIGraphicsGetImageFromCurrentImageContext();
    return img;
}

UINavigationBar默認(rèn)是透明的,有滑動時(shí)會逐漸變?yōu)槟:Ч椋梢酝ㄟ^改變scrollEdgeAppearance屬性直接變?yōu)槟:Ч?/p>

if (@available(iOS 15.0, *)){
    UINavigationBarAppearance *appearance = [[UINavigationBarAppearance alloc] init];
    appearance.backgroundEffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleRegular];
    navBar.scrollEdgeAppearance = appearance;
}

2闻妓、UITableView新增了一條新屬性:sectionHeaderTopPadding, 默認(rèn)會給每一個(gè)section header 增加一個(gè)高度掠械,當(dāng)我們使用 UITableViewStylePlain 初始化UITableView的時(shí)候由缆,能發(fā)現(xiàn)sectionHeader增高了22px。解決辦法就是手動去除這個(gè)高度

if (@available(iOS 15.0, *)) {
    table.sectionHeaderTopPadding = 0;
}

全局適配設(shè)置

if (@available(iOS 15.0, *)) {
    //設(shè)置默認(rèn)的分組頭部間隙為0
    [UITableView appearance].sectionHeaderTopPadding = CGFLOAT_MIN;
}

3猾蒂、UIImageWriteToSavedPhotosAlbum存儲圖片之后的回調(diào)不再返回圖片了均唉,會返回nil,如果在回調(diào)方法里面操作image有可能會直接Crash肚菠,目前的解決辦法聲明一個(gè)全局image去記錄舔箭,后面再去操作

self.image = image;
UIImageWriteToSavedPhotosAlbum(image,self,@selector(image:didFinishSavingWithError:contextInfo:), NULL);
            
- (void)image:(UIImage *)image didFinishSavingWithError:(NSError *)error contextInfo:(void *)contextInfo{
    // self.image doing...
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市蚊逢,隨后出現(xiàn)的幾起案子层扶,更是在濱河造成了極大的恐慌,老刑警劉巖时捌,帶你破解...
    沈念sama閱讀 211,423評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件怒医,死亡現(xiàn)場離奇詭異,居然都是意外死亡奢讨,警方通過查閱死者的電腦和手機(jī)稚叹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,147評論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來拿诸,“玉大人扒袖,你說我怎么就攤上這事∧堵耄” “怎么了季率?”我有些...
    開封第一講書人閱讀 157,019評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長描沟。 經(jīng)常有香客問我飒泻,道長鞭光,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,443評論 1 283
  • 正文 為了忘掉前任泞遗,我火速辦了婚禮惰许,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘史辙。我一直安慰自己汹买,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,535評論 6 385
  • 文/花漫 我一把揭開白布聊倔。 她就那樣靜靜地躺著晦毙,像睡著了一般。 火紅的嫁衣襯著肌膚如雪耙蔑。 梳的紋絲不亂的頭發(fā)上见妒,一...
    開封第一講書人閱讀 49,798評論 1 290
  • 那天,我揣著相機(jī)與錄音纵潦,去河邊找鬼徐鹤。 笑死,一個(gè)胖子當(dāng)著我的面吹牛邀层,可吹牛的內(nèi)容都是我干的返敬。 我是一名探鬼主播,決...
    沈念sama閱讀 38,941評論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼寥院,長吁一口氣:“原來是場噩夢啊……” “哼劲赠!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起秸谢,我...
    開封第一講書人閱讀 37,704評論 0 266
  • 序言:老撾萬榮一對情侶失蹤凛澎,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后估蹄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體塑煎,經(jīng)...
    沈念sama閱讀 44,152評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,494評論 2 327
  • 正文 我和宋清朗相戀三年臭蚁,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了最铁。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,629評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡垮兑,死狀恐怖冷尉,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情系枪,我是刑警寧澤雀哨,帶...
    沈念sama閱讀 34,295評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響雾棺,放射性物質(zhì)發(fā)生泄漏膊夹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,901評論 3 313
  • 文/蒙蒙 一垢村、第九天 我趴在偏房一處隱蔽的房頂上張望割疾。 院中可真熱鬧,春花似錦嘉栓、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至奠支,卻和暖如春馋辈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背倍谜。 一陣腳步聲響...
    開封第一講書人閱讀 31,978評論 1 266
  • 我被黑心中介騙來泰國打工迈螟, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人尔崔。 一個(gè)月前我還...
    沈念sama閱讀 46,333評論 2 360
  • 正文 我出身青樓答毫,卻偏偏與公主長得像,于是被迫代替她去往敵國和親季春。 傳聞我的和親對象是個(gè)殘疾皇子洗搂,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,499評論 2 348

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