iOS15適配小結(jié)
1、tabbar及navicationbar的背景顏色問(wèn)題
問(wèn)題:從ios14升級(jí)到ios15會(huì)出現(xiàn) 導(dǎo)航欄背景顏色失效
原因:因?yàn)樵O(shè)置顏色方法在ios15中失效
--在iOS13更新的API中新增了針對(duì)navigationBar,tabbar分別新增了新的屬性專門(mén)管理這些滑動(dòng)時(shí)候產(chǎn)生的顏色透明等等信息,由于我們應(yīng)用兼容iOS10以上,對(duì)于導(dǎo)航欄的設(shè)置還沒(méi)有使用UINavigationBarAppearance和UITabBarAppearance,但在更新的iOS15上失效,所以就變得設(shè)置失效
//設(shè)置navigationBar顏色 self.navigationController.navigationBar.barTintColor = [UIColor blueColor]; //設(shè)置tabBar背景色 self.tabBarController.tabBar.backgroundColor = [UIColor blueColor]; //設(shè)置tabBarItem字體顏色 NSMutableDictionary<NSAttributedStringKey, id> *normalAttributes = [NSMutableDictionary dictionary]; [normalAttributes setValue:[UIColor blueColor] forKey:NSForegroundColorAttributeName]; [self.tabBarItem setTitleTextAttributes:normalAttributes.copy forState:UIControlStateNormal]; [self.tabBarItem setTitleTextAttributes:normalAttributes.copy forState:UIControlStateSelected];
解決方法--重新設(shè)置相關(guān)屬性
tabBar
UITabBarAppearance *appearance = [[UITabBarAppearance alloc] init]; //tabBaritem title選中狀態(tài)顏色 appearance.stackedLayoutAppearance.selected.titleTextAttributes = @{ NSForegroundColorAttributeName:[UIColor blueColor], }; //tabBaritem title未選中狀態(tài)顏色 appearance.stackedLayoutAppearance.normal.titleTextAttributes = @{ NSForegroundColorAttributeName:[UIColor blueColor], }; //tabBar背景顏色 appearance.backgroundColor = [UIColor blackColor]; self.tabBarItem.scrollEdgeAppearance = appearance; self.tabBarItem.standardAppearance = appearance;
其中 standardAppearance和scrollEdgeAppearance等的區(qū)別
- standardAppearance --- 常規(guī)狀態(tài)
- scrollEdgeAppearance --- 小屏幕手機(jī)橫屏?xí)r的狀態(tài)
- scrollEdgeAppearance --- 唄scrollview向下拉的狀態(tài)
navigationBar
UINavigationBarAppearance *appearance = [[UINavigationBarAppearance alloc] init]; appearance.backgroundColor = [UIColor blackColor]; self.navigationBar.standardAppearance = appearance; self.navigationBar.scrollEdgeAppearance = appearance;
2、tableview新屬性-sectionHeaderTopPadding
官方支持
/// Determines if the table view allows its cells to become focused. /// When tableView:canFocusRowAtIndexPath: is implemented, its return value takes precedence over this method. /// Defaults to a system derived value based on platform and other properties of the table view. @property (nonatomic, getter=isPrefetchingEnabled) BOOL prefetchingEnabled
iOS 15中tableView會(huì)給每一個(gè)section的頂部(header以上)再加上一個(gè)22像素的高度,形成一個(gè)section和section之間的間距
使用
為了配合以前的開(kāi)發(fā)習(xí)慣,我們只需要在創(chuàng)建實(shí)例的時(shí)候進(jìn)行對(duì)間距的設(shè)置即可
if (@available(iOS 15.0, *)) { tableView.sectionHeaderTopPadding = 0; }
或者全局設(shè)置
if (@available(iOS 15.0, *)) { [UITableView appearance].sectionHeaderTopPadding = 0; }
到此這篇關(guān)于iOS15適配小結(jié)的文章就介紹到這了,更多相關(guān)iOS15適配內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用UItableview在iOS應(yīng)用開(kāi)發(fā)中實(shí)現(xiàn)好友列表功能
這篇文章主要介紹了使用UItableview在iOS應(yīng)用開(kāi)發(fā)中實(shí)現(xiàn)一個(gè)好友列表功能的方法,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-12-12iOS 使用UITextField自定義搜索框 實(shí)現(xiàn)用戶輸入完之后“實(shí)時(shí)搜索”功能
這篇文章主要介紹了iOS 使用UITextField自定義搜索框 實(shí)現(xiàn)用戶輸入完之后“實(shí)時(shí)搜索”功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03iOS如何將UIButton中的圖片與文字上下對(duì)齊詳解
對(duì)于UIButton實(shí)現(xiàn)上顯示圖片,下顯示文字這個(gè)需求估計(jì)各位iOS開(kāi)發(fā)者們都不陌生,所以下面這篇文章主要給大家介紹了關(guān)于iOS如何將UIButton中圖片與文字上下對(duì)齊的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-10-10iOS開(kāi)發(fā)實(shí)現(xiàn)圖片瀏覽功能
這篇文章主要為大家詳細(xì)介紹了iOS開(kāi)發(fā)實(shí)現(xiàn)圖片瀏覽功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01利用iOS開(kāi)發(fā)實(shí)現(xiàn)翻轉(zhuǎn)撲克牌動(dòng)畫(huà)的方法
這篇文章主要給大家介紹了關(guān)于利用iOS開(kāi)發(fā)實(shí)現(xiàn)翻撲克牌動(dòng)畫(huà)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)跟著小編一起學(xué)習(xí)學(xué)習(xí)吧。2017-07-07IOS中快速集成短信SDK驗(yàn)證開(kāi)發(fā)(SMSSDK),IOS開(kāi)發(fā)中如何設(shè)置手機(jī)短信驗(yàn)證碼
這篇文章主要介紹了IOS中快速集成短信SDK驗(yàn)證開(kāi)發(fā)(SMSSDK),IOS開(kāi)發(fā)中如何設(shè)置手機(jī)短信驗(yàn)證碼 的相關(guān)資料,需要的朋友可以參考下2016-01-01