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]}]; ///新的實現(xiàn)

在Xcode10上編譯不會有問題荡碾,但是在Xcode11上編譯的會崩潰劳殖。并且- (void)setValue:(nullable id)value forKey:(NSString *)key方法沒問題,- (void)setValue:(nullable id)value forKeyPath:(NSString *)keyPath會崩潰

2.presentViewController的問題

會出現(xiàn)這種情況是主要是因為我們之前對UIViewController里面的一個屬性,即modalPresentationStyle(該屬性是控制器在模態(tài)視圖時將要使用的樣式)沒有設(shè)置需要的類型箕昭。在iOS13中modalPresentationStyle的默認(rèn)改為UIModalPresentationAutomatic,而在之前默認(rèn)是UIModalPresentationFullScreen。

這個不受Xcode版本的影響朱转,只要是iOS13的系統(tǒng)夺刑,沒有顯式設(shè)置modalPresentationStyle茎杂,就會有這個問題

3.即將廢棄的 LaunchImage

從 iOS 8 的時候错览,蘋果就引入了 LaunchScreen,我們可以設(shè)置 LaunchScreen來作為啟動頁煌往。當(dāng)然倾哺,現(xiàn)在你還可以使用LaunchImage來設(shè)置啟動圖。不過使用LaunchImage的話刽脖,要求我們必須提供各種屏幕尺寸的啟動圖羞海,來適配各種設(shè)備,隨著蘋果設(shè)備尺寸越來越多曲管,這種方式顯然不夠 Flexible却邓。而使用 LaunchScreen的話,情況會變的很簡單院水, LaunchScreen是支持AutoLayout+SizeClass的腊徙,所以適配各種屏幕都不在話下。 注意啦??檬某,從2020年4月開始撬腾,所有使? iOS13 SDK 的 App 將必須提供 LaunchScreen,LaunchImage即將退出歷史舞臺

4.暗黑模式

原理

1.將同一個資源恢恼,創(chuàng)建出兩種模式的樣式民傻。系統(tǒng)根據(jù)當(dāng)前選擇的樣式,自動獲取該樣式的資源

2.每次系統(tǒng)更新樣式時场斑,應(yīng)用會調(diào)用當(dāng)前所有存在的元素調(diào)用對應(yīng)的一些重新方法漓踢,進行重繪視圖,可以在對應(yīng)的方法做相應(yīng)的改動

資源文件適配

1.創(chuàng)建一個Assets文件(或在現(xiàn)有的Assets文件中)

2.新建一個圖片資源文件(或者顏色資源文件漏隐、或者其他資源文件)

3.選中該資源文件彭雾, 打開 Xcode ->View ->Inspectors ->Show Attributes Inspectors (或者Option+Command+4)視圖,將Apperances 選項 改為Any锁保,Dark

4.執(zhí)行完第三步薯酝,資源文件將會有多個容器框半沽,分別為 Any Apperance 和 Dark Apperance. Any Apperance 應(yīng)用于默認(rèn)情況(Unspecified)與高亮情況(Light), Dark Apperance 應(yīng)用于暗黑模式(Dark)

5.代碼默認(rèn)執(zhí)行時吴菠,就可以正常通過名字使用了者填,系統(tǒng)會根據(jù)當(dāng)前模式自動獲取對應(yīng)的資源文件

注意

同一工程內(nèi)多個Assets文件在打包后,就會生成一個Assets.car 文件做葵,所以要保證Assets內(nèi)資源文件的名字不能相同

UIView

traitCollectionDidChange(_:)

layoutSubviews()

draw(_:)

updateConstraints()

tintColorDidChange()

UIViewController


traitCollectionDidChange(_:)

updateViewConstraints()

viewWillLayoutSubviews()

viewDidLayoutSubviews()

UIPresentationController


traitCollectionDidChange(_:)

containerViewWillLayoutSubviews()

containerViewDidLayoutSubviews()

全局關(guān)閉黑暗模式

方式一? 配置plist文件: 在Info.plist 文件中占哟,添加UIUserInterfaceStyle key 名字為 User Interface Style 值為String,將UIUserInterfaceStyle key 的值設(shè)置為 Light

在開發(fā)中酿矢,如果用的系統(tǒng)控件(如cell榨乎、tableview的背景色)未設(shè)置背景色(或者為透明),則進入暗黑模式后瘫筐,控件背景色變?yōu)楹谏?/p>

可以每一個頁面設(shè)置蜜暑,當(dāng)然也可以整體設(shè)置,

一般我們的APP都是在一個window下的策肝,那就整體設(shè)置APP里的window

方式二 :代碼關(guān)閉黑暗模式 強制關(guān)閉暗黑模式

#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 設(shè)置為對應(yīng)的模式肛捍,則強制限制該元素與其子元素以設(shè)置的模式進行展示,不跟隨系統(tǒng)模式改變進行改變

設(shè)置 ViewController 的該屬性之众, 將會影響視圖控制器的視圖和子視圖控制器采用該樣式

設(shè)置 View 的該屬性拙毫, 將會影響視圖及其所有子視圖采用該樣式

設(shè)置 Window 的該屬性, 將會影響窗口中的所有內(nèi)容都采用樣式棺禾,包括根視圖控制器和在該窗口中顯示內(nèi)容的所有演示控制器(UIPresentationController)

iOS適配暗黑模式:https://www.jb51.net/article/169853.htm

5.增加一直使用藍(lán)牙的權(quán)限申請

CBCentralManager缀蹄,iOS13以前,使用藍(lán)牙時可以直接用膘婶,不會出現(xiàn)權(quán)限提示缺前,iOS13后,再使用就會提示了竣付。

在info.plist里增加

<key>NSBluetoothAlwaysUsageDescription</key>

<string>我們要一直使用您的藍(lán)牙诡延,具體做什么別問我</string>`

6.使用MJExtension 中處理NSNull的不同

這個直接會導(dǎo)致Crash的在將服務(wù)端數(shù)據(jù)字典轉(zhuǎn)換為模型時,如果遇到服務(wù)端給的數(shù)據(jù)為NSNull時古胆,

mj_JSONObject肆良,其中 class_copyPropertyList方法得到的屬性里,多了一種EFSQLBinding類型的東西逸绎,而且屬性數(shù)量也不準(zhǔn)確惹恃,那就沒辦法了,我只能改寫這個方法了棺牧,這個組件沒有更新的情況下巫糙,寫了一個方法swizzling掉把當(dāng)遇到 NSNull時,直接轉(zhuǎn)為nil了颊乘。

7. WKWebView 中測量頁面內(nèi)容高度的方式變更

iOS 13以前

document.body.scrollHeight

iOS 13中

document.documentElement.scrollHeight

兩者相差55 應(yīng)該是瀏覽器定義高度變了

8. 友盟消息推送参淹,獲取deviceToken適配

- (void)application:(UIApplication *)application

didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken

{

?if(![deviceToken isKindOfClass:[NSData class]]) return;

??constunsigned *tokenBytes = (constunsigned *)[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 與之前版本不同

目前狀態(tài)欄也增加了一種模式醉锄,由之前的兩種,變成了三種, 其中default由之前的黑色內(nèi)容浙值,變成了會根據(jù)系統(tǒng)模式恳不,自動選擇當(dāng)前展示lightContent還是darkContent

10. fishhook 導(dǎo)致的Crash (https://github.com/facebook/fishhook/issues/61))


原文:https://juejin.im/post/5d745f8af265da03b5746fa0

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市开呐,隨后出現(xiàn)的幾起案子烟勋,更是在濱河造成了極大的恐慌,老刑警劉巖筐付,帶你破解...
    沈念sama閱讀 206,013評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件卵惦,死亡現(xiàn)場離奇詭異,居然都是意外死亡瓦戚,警方通過查閱死者的電腦和手機沮尿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,205評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來伤极,“玉大人蛹找,你說我怎么就攤上這事姨伤∩谄海” “怎么了?”我有些...
    開封第一講書人閱讀 152,370評論 0 342
  • 文/不壞的土叔 我叫張陵乍楚,是天一觀的道長当编。 經(jīng)常有香客問我,道長徒溪,這世上最難降的妖魔是什么忿偷? 我笑而不...
    開封第一講書人閱讀 55,168評論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮臊泌,結(jié)果婚禮上鲤桥,老公的妹妹穿的比我還像新娘。我一直安慰自己渠概,他們只是感情好茶凳,可當(dāng)我...
    茶點故事閱讀 64,153評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著播揪,像睡著了一般贮喧。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上猪狈,一...
    開封第一講書人閱讀 48,954評論 1 283
  • 那天箱沦,我揣著相機與錄音,去河邊找鬼雇庙。 笑死谓形,一個胖子當(dāng)著我的面吹牛灶伊,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播寒跳,決...
    沈念sama閱讀 38,271評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼谁帕,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了冯袍?” 一聲冷哼從身側(cè)響起匈挖,我...
    開封第一講書人閱讀 36,916評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎康愤,沒想到半個月后儡循,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,382評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡征冷,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,877評論 2 323
  • 正文 我和宋清朗相戀三年择膝,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片检激。...
    茶點故事閱讀 37,989評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡肴捉,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出叔收,到底是詐尸還是另有隱情齿穗,我是刑警寧澤,帶...
    沈念sama閱讀 33,624評論 4 322
  • 正文 年R本政府宣布饺律,位于F島的核電站窃页,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏复濒。R本人自食惡果不足惜脖卖,卻給世界環(huán)境...
    茶點故事閱讀 39,209評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望巧颈。 院中可真熱鬧畦木,春花似錦、人聲如沸砸泛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,199評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽晾嘶。三九已至妓雾,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間垒迂,已是汗流浹背械姻。 一陣腳步聲響...
    開封第一講書人閱讀 31,418評論 1 260
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人楷拳。 一個月前我還...
    沈念sama閱讀 45,401評論 2 352
  • 正文 我出身青樓绣夺,卻偏偏與公主長得像,于是被迫代替她去往敵國和親欢揖。 傳聞我的和親對象是個殘疾皇子陶耍,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,700評論 2 345

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

  • ios13 UISegmentedControl 的 setTintColor 屬性失效, 新增了一個setSe...
    海利昂閱讀 9,166評論 3 5
  • iOS13適配 1.私有KVC 在Xcode10上編譯不會有問題她混,但是在Xcode11上編譯的會崩潰烈钞。并且- (v...
    輕重緩急閱讀 577評論 0 1
  • 1.私有KVC 在Xcode10上編譯不會有問題,但是在Xcode11上編譯的會崩潰坤按。并且- (void)setV...
    iOS亮子閱讀 916評論 0 2
  • 對iOS13 適配的總結(jié)毯欣,下面有些是自己遇到的,有些是收集的臭脓,希望能給大家一些思路 iOS13中presentVi...
    1劍天下閱讀 7,449評論 2 9
  • 原文博客地址: iOS13適配深色模式(Dark Mode) 好像大概也許是一年前, Mac OS系統(tǒng)發(fā)布了深色模...
    TitanCoder閱讀 36,912評論 8 61