您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關如何適配iOS13,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
1.私有KVC
[self setValue:baseTabBar forKey:@"tabBar"]; //正常 [_textField setValue:[UIColor redColor] forKeyPath:@"_placeholderLabel.textColor"];///崩潰 [_textField setValue:[UIFont systemFontOfSize:14] forKeyPath:@"_placeholderLabel.font"];///崩潰 _textField.attributedPlaceholder = [[NSAttributedString alloc] initWithString:@"姓名" attributes:@{NSFontAttributeName:[UIFont systemFontOfSize:14],NSForegroundColorAttributeName:[UIColor redColor]}]; ///新的實現
在Xcode10上編譯不會有問題,但是在Xcode11上編譯的會崩潰。并且- (void)setValue:(nullable id)value forKey:(NSString *)key方法沒問題,- (void)setValue:(nullable id)value forKeyPath:(NSString *)keyPath會崩潰
2.presentViewController的問題
會出現這種情況是主要是因為我們之前對UIViewController里面的一個屬性,即modalPresentationStyle(該屬性是控制器在模態視圖時將要使用的樣式)沒有設置需要的類型。在iOS13中modalPresentationStyle的默認改為UIModalPresentationAutomatic,而在之前默認是UIModalPresentationFullScreen。
這個不受Xcode版本的影響,只要是iOS13的系統,沒有顯式設置modalPresentationStyle,就會有這個問題
3.即將廢棄的 LaunchImage
從 iOS 8 的時候,蘋果就引入了 LaunchScreen,我們可以設置 LaunchScreen來作為啟動頁。當然,現在你還可以使用LaunchImage來設置啟動圖。不過使用LaunchImage的話,要求我們必須提供各種屏幕尺寸的啟動圖,來適配各種設備,隨著蘋果設備尺寸越來越多,這種方式顯然不夠 Flexible。而使用 LaunchScreen的話,情況會變的很簡單, LaunchScreen是支持AutoLayout+SizeClass的,所以適配各種屏幕都不在話下。 注意啦??,從2020年4月開始,所有使? iOS13 SDK 的 App 將必須提供 LaunchScreen,LaunchImage即將退出歷史舞臺
4.暗黑模式
原理
1.將同一個資源,創建出兩種模式的樣式。系統根據當前選擇的樣式,自動獲取該樣式的資源
2.每次系統更新樣式時,應用會調用當前所有存在的元素調用對應的一些重新方法,進行重繪視圖,可以在對應的方法做相應的改動
資源文件適配
1.創建一個Assets文件(或在現有的Assets文件中)
2.新建一個圖片資源文件(或者顏色資源文件、或者其他資源文件)
3.選中該資源文件, 打開 Xcode ->View ->Inspectors ->Show Attributes Inspectors (或者Option+Command+4)視圖,將Apperances 選項 改為Any,Dark
4.執行完第三步,資源文件將會有多個容器框,分別為 Any Apperance 和 Dark Apperance. Any Apperance 應用于默認情況(Unspecified)與高亮情況(Light), Dark Apperance 應用于暗黑模式(Dark)
5.代碼默認執行時,就可以正常通過名字使用了,系統會根據當前模式自動獲取對應的資源文件
注意
同一工程內多個Assets文件在打包后,就會生成一個Assets.car 文件,所以要保證Assets內資源文件的名字不能相同
UIView
traitCollectionDidChange(_:) layoutSubviews() draw(_:) updateConstraints() tintColorDidChange()
UIViewController
traitCollectionDidChange(_:) updateViewConstraints() viewWillLayoutSubviews() viewDidLayoutSubviews()
UIPresentationController
traitCollectionDidChange(_:) containerViewWillLayoutSubviews() containerViewDidLayoutSubviews()
全局關閉黑暗模式
方式一 配置plist文件: 在Info.plist 文件中,添加UIUserInterfaceStyle key 名字為 User Interface Style 值為String,將UIUserInterfaceStyle key 的值設置為 Light
在開發中,如果用的系統控件(如cell、tableview的背景色)未設置背景色(或者為透明),則進入暗黑模式后,控件背景色變為黑色。
可以每一個頁面設置,當然也可以整體設置,
一般我們的APP都是在一個window下的,那就整體設置APP里的window
方式二 :代碼關閉黑暗模式 強制關閉暗黑模式
#if defined(__IPHONE_13_0) && __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_13_0 if(@available(iOS 13.0,*)){ self.window.overrideUserInterfaceStyle = UIUserInterfaceStyleLight; } #endif
單個界面不遵循暗黑模式
UIViewController與UIView 都新增一個屬性 overrideUserInterfaceStyle
將 overrideUserInterfaceStyle 設置為對應的模式,則強制限制該元素與其子元素以設置的模式進行展示,不跟隨系統模式改變進行改變
設置 ViewController 的該屬性, 將會影響視圖控制器的視圖和子視圖控制器采用該樣式
設置 View 的該屬性, 將會影響視圖及其所有子視圖采用該樣式
設置 Window 的該屬性, 將會影響窗口中的所有內容都采用樣式,包括根視圖控制器和在該窗口中顯示內容的所有演示控制器(UIPresentationController)
iOS適配暗黑模式:https://www.jb51.net/article/169853.htm
5.增加一直使用藍牙的權限申請
CBCentralManager,iOS13以前,使用藍牙時可以直接用,不會出現權限提示,iOS13后,再使用就會提示了。
在info.plist里增加
<key>NSBluetoothAlwaysUsageDescription</key> <string>我們要一直使用您的藍牙,具體做什么別問我</string>`
6.使用MJExtension 中處理NSNull的不同
這個直接會導致Crash的在將服務端數據字典轉換為模型時,如果遇到服務端給的數據為NSNull時,
mj_JSONObject,其中 class_copyPropertyList方法得到的屬性里,多了一種EFSQLBinding類型的東西,而且屬性數量也不準確,那就沒辦法了,我只能改寫這個方法了,這個組件沒有更新的情況下,寫了一個方法swizzling掉把當遇到 NSNull時,直接轉為nil了。
7. WKWebView 中測量頁面內容高度的方式變更
iOS 13以前
document.body.scrollHeight
iOS 13中
document.documentElement.scrollHeight
兩者相差55 應該是瀏覽器定義高度變了
8. 友盟消息推送,獲取deviceToken適配
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken { if (![deviceToken isKindOfClass:[NSData class]]) return; const unsigned *tokenBytes = (const unsigned *)[deviceToken bytes]; NSString *hexToken = [NSString stringWithFormat:@"%08x%08x%08x%08x%08x%08x%08x%08x",ntohl(tokenBytes[0]), ntohl(tokenBytes[1]), ntohl(tokenBytes[2]),ntohl(tokenBytes[3]), ntohl(tokenBytes[4]), ntohl(tokenBytes[5]),ntohl(tokenBytes[6]),ntohl(tokenBytes[7])]; pushDeviceToken = hexToken; NSLog(@"deviceToken:%@",hexToken); }
9. StatusBar 與之前版本不同
目前狀態欄也增加了一種模式,由之前的兩種,變成了三種, 其中default由之前的黑色內容,變成了會根據系統模式,自動選擇當前展示lightContent還是darkContent
10. fishhook 導致的Crash (https://github.com/facebook/fishhook/issues/61))
以上就是如何適配iOS13,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。